My VSTO Outlook Add-in suddenly stopped working on one customer machine (it does not load, no error message) and I'm stuck with troubleshooting. The machine is Windows 7 x86, Outlook 2007. The add-in is written with Visual Studio 2008 and uses VSTO 2005 with the 2003 PIAs (because we need to support Outlook 2003 as well). It works perfectly fine on other machines.
Here's what I tried to get useful troubleshooting output:
- Add the
VSTO_SUPPRESSDISPLAYALERTS
environment variable (set to0
). - Start Outlook with administrative permissions.
- Look into the event log.
Nothing. The add-in just won't load without giving any indication of the reason. I've also checked the "usual suspects" (CAS policy, PIAs installed, LoadBehavior in the registry, reinstalling VSTO and the add-in).
Some other observations:
LoadBehavior
in the registry stays at3
.- The add-in shows up as "disabled" in Outlook. Checking its checkbox in "COM add-ins" just does nothing (no error, checkbox is cleared again when entering the form a second time).
- It works perfectly fine on other customer machines, and it worked perfectly fine on this machine. (No, the customer cannot tell me what changed on his machine.)
- I have a
Trace.WriteLine
message at the very top of my code (first line in theThisAddIn_Startup
handler), which is not reached (I checked with DebugView). Thus, the reason for not loading is not an exception in my add-in but rather a failure of VSTO to load the add-in or of Outlook to load VSTO.
Instead of more random debugging ("try this...", "try that..."), I'd really like to force Outlook and/or VSTO to tell me what's wrong, i.e. to give me a useful error message instead of just doing nothing when trying to enable the add-in. Any ideas?
Eventually I coaxed Word to tell me:
After that, thanks to [1], FusLogvw quickly solved the problem for me.
[1] Could not load file or assembly or one of its dependencies
Did you try enabling the add-in again? It won't run after its in the disabled queue. After you re-enable it from the disabled add-in screen, you can then check the box in the COM-AddIn screen to have it load which then should prompt you more detail since you set the
VSTO_SUPPRESSDISPLAYALERTS
variable about what may have happened in the first place.There is also another possibility here as to why you are getting no feedback even with the Environment Variables mentioned above being set. I found if you were getting this error after an install (not a previous VSTO that had been working) you should also double check the registry and the "Manifest" entry if you have one.
While Jeremy Thompson points out the Registry in his Second bullet point he does not show the Manifest entry that could be part of your registry settings. If your Manifest entry is not pointing to the correct path and file it will show up in the Add-Ins listing with an entry of "Not Loaded".
Here we see a bad entry that just points to the VSTO file only, no path.
This will cause your AddIn to look like it loaded with errors, but no errors are popping up and appearing for you and making things frustrating. So it will look like this below, notice the location entry below also does not show the path.
Correct the entry by putting in the proper path along with the file name and it will fix this.
The lack of errors I assume comes from the fact that you were pointing at nothing initially, so it lists the AddIn because it is in the registry, even though there is nothing to load.
Funny for me, I tried a reboot. Fixed it for me. However, The reason it fixed it for me, is I had a rogue Excel.exe running hidden. The addin was not starting due to this other excel application running (I was migrating an MSAccess application to VSTO), so Access had an automation app open hidden.
In short, if your addin is not starting up, quick check for is to just make sure there's no other Excel applications running. This of course only applies when you're trying to get a brand new one installed/up and running.
(I used this link) https://www.add-in-express.com/creating-addins-blog/2012/11/13/wix-installation-vsto-office-addin/
I would suggest using a Microsoft tool to diagnose add-in issues called AddinSpy.
I know this is old but for various reasons I've recently been troubleshooting Office Add-Ins that dont load.
Its chewed up heaps of time so I thought I'd share, so if your add-in wont load or its not visible or etc please try these solutions.
1). The Add-In is not loaded.
Not loaded. A runtime error occurred during the loading of the COM Add-In.
The problem is due to missing .Net framework 3.5 or 4.0.
Note: on a x64 I only need .Net 4.0 however on a x86 PC I got the error after installing .Net 4.0. Following this article I installed .Net 3.5 as well and then it worked on the x86 PC!
2). The Add-In is not loaded.
Double check you have spelt the registry keys correctly. Occassionally I type Behaviour but in American spelling is Behavior, so double check "LoadBehavior"
Also make sure "LoadBehavior" is 3, for a list of values see http://msdn.microsoft.com/en-us/library/vstudio/bb386106.aspx#LoadBehavior
3). The Add-In is not visible.
You can make the add-In visible by going to Excel > File > Options > Add-Ins > select the Manage dropdownlist and set it to COM Add-Ins > Click GO. In the COM Add-Ins dialog make sure that Add-In is ticked.
4). The Add-In was disabled.
Alternatively the add-in may be hidden because it has been disabled. You can enable the add-In by going to Excel > File > Options > Add-Ins > select the Manage dropdownlist and set it Disabled and click GO. Select the Add-In that has been disabled and click Enable.
5). The ExcelDNA User Defined Formula is not rendering correctly
Instead of seeing the cell value you see: #NAME?
Set the following registry key:
With the correct value:
6). Excel HANGS after showing a messagebox
Turn back on the application settings:
7). Further troubleshooting
Enable your VSTO log file by adding the following on your system environment variables:
There might be an exception error that is why your add-in is not loading.
You can check this source for more info on VSTO logging and alerts, but in essence you change two environment variable values depending on what you need to do: