1

I am struggling with Windows Installer since 2 days now. I have a c# project under visual studio 2010, my application just fills a ControlTab using Spring.Net. The Spring configuration files are located in a library class (once again without custom actions everything work fine).

Based on the Walkthrough: http://msdn.microsoft.com/en-us/library/9cdb5eda%28v=vs.100%29.aspx. I created a simple project with the same structure as my project : a windows form application uses a spring configuration file located in a class library to initialize a button on my form. The custom action I implemented works fine for this simple project but when I do exactly the same step on my project, the installation of the msi file failed with the following error (retrieved with msiexe):

#DEBUG: Error 2835:  The control ErrorIcon was not found on dialog ErrorDialog
When installing this package, an unexpected error has occurred. This may indicate a problem with this package. The error code is 2835th Arguments: ErrorIcon, ErrorDialog,
Error 1001. Error 1001. The installer types in the assembly C:\...\TestSpring.exe can not be queried. -> At least one type in the assembly can not be loaded. Retrieve the LoaderExceptions property if you need further information.
MSI (s) (60!C4) [09:10:37:263]: 
MSI (s) (60:70) [09:10:37:263]: Leaked MSIHANDLE (111) of type 790531 for thread 20932
MSI (s) (60:70) [09:10:37:263]: Note: 1: 2769 2: _489C2921_6B59_42E8_A55A_399B1A3D2382.install 3: 1 
DEBUG: Error 2769:  Custom Action _489C2921_6B59_42E8_A55A_399B1A3D2382.install did not close 1 MSIHANDLEs.
When installing this package, an unexpected error has occurred. This may indicate a problem with this package. The error code is 2769. Argumente: _489C2921_6B59_42E8_A55A_399B1A3D2382.install, 1, 
CustomAction _489C2921_6B59_42E8_A55A_399B1A3D2382.install returned actual error code 1603 (note this may not be 100% accurate if translation happened inside sandbox)
Aktion beendet um 09:10:37: InstallExecute. return value 3.

I guess the error is the one with code 1603 when trying to install the application (I use the installer class given in the Walkthrough)

I compared my two projects, there are no differences (my project is just bigger than the one used to test custom action)

I tried that: My installation failed (missing DLL). What do I do to correct this?: setting all the projects checked as Build and try to change the configuration from Debug to Release. Once that done I close the property windows, reopen it: the mode is not Release anymore but Debug. I used msiexe and orca to try to find the reason of my error but I could not find it.

I read: Windows installer: Error 1001, CustomAction _xxxxx.install returned actual error code 1603 but it does not seem to be the same error as in my case

Any idea on what I could check?

ps: I tried my project with a custom action but with InstallerClass set to False, the application is then launched before the end of the installation, I close the application and then the installation runs till its end. Is it normal that the application is launched before the end of the installation?

update1:

I did all the process again on my project:

  • creating an installer class
  • set Installclass to True

BUT I did not implement any of the method of the class Installer, so my Installer1 class is:

[RunInstaller(true)]
public partial class Installer1 : System.Configuration.Install.Installer
{
    public Installer1()
    {
        InitializeComponent();
´   }
}

And I still retrieve the same error. So the error does not come of my Installer1 class since my project with an Installer class with the default content also raises the same error. So does the error come from .NET? but then why did it work with the first test I made on my simple project?

update2: I created an installation without a folder to store the dll, the installation works.

I created log files with msiexec and used logview but I have not found why my installer fails, even if the installation works without DLL folder, I still do not know why my installer fails when I define a folder where to store the dll.

Community
  • 1
  • 1
eqtèöck
  • 971
  • 1
  • 13
  • 27
  • Could you please elaborate on this - `my installer fails when I define a folder where to store the dll`? It looks like you deploy `TestSpring.exe` to some folders but all its dependencies are not there in that folder. – YK1 Jun 14 '13 at 21:12
  • The installation fails when I define a custom action and when the dll that my project needs are in a folder. An installer with the same configuration (all needed dll in a folder) but without custom action works fine. An installer with a custom action and with all needed dll at the same level as the installer works also fine. All dll I need are the library class with my spring configuration file, common.logging, log4net, springAop and Spring.core. A simpler project´s installer with a folder with dll (my library class, common.logging and spring.core) and custom action works fine. – eqtèöck Jun 18 '13 at 07:16
  • `simpler project´s installer with a folder..... works fine` - means problem not with creating folder or custom action - problem is with your assemblies. Can you enable fusion logging and run the problematic installation. Fusion logs may give you some clue about whats going on - http://msdn.microsoft.com/en-us/library/e74a18c4(v=vs.110).aspx – YK1 Jun 18 '13 at 09:23

0 Answers0