So, one of my websites has a PreApplicationStartMethod that should run before the application starts:
[assembly: PreApplicationStartMethod(typeof(ServiceStackAppHost), "Start")]
This methods does some bootstrapping and relies on some configuration being set.
Now, I want to compile the website as part of my automated build process – so I invoke aspnet_compiler.exe, which fails because it runs the PreApplicationStartMethod:
AfterBuild:
C:\Windows\Microsoft.NET\Framework64\v4.0.30319\aspnet_compiler.exe -v
temp -p C:\Projects\ error ASPRUNTIME : The pre-application
start initialization method Start on type
RedactedNameSpace.ServiceStackAppHost threw an exception with the
following error message: Resolution of the dependency failed, type =
“…”
How do I avoid aspnet_compiler.exe invoking the PreApplicationStartMethod when compiling the website ?
The short answer is that you can’t prevent it from running, and that this is by design but you can workaround the problem.
Why PreApplicationStart methods run during aspnet_compiler.exe
The reason is that
PreApplicationStartMethod(or WebActivator, which builds on top of it) can be used for things that actually affect compilation, such that if you omitted it the site may not compile.To give you an example, you can add namespaces to the compilation in a
PreAppStartmethod, which then affects compilation of your Razor pages.Obviously, not every
PreAppStartmethod needs to run when you use aspnet_precompiler, but we do run all of them in case they are needed.Detecting whether you’re running under aspnet_compiler.exe
If the code in there breaks under aspnet_compiler, it may be necessary to add conditional logic in the
PreAppStartmethod to detect the situation and omit running the code.You can look at
System.Web.Hosting.HostingEnvironment.InClientBuildManagerpropery to determine whether yourPreAppStartmethod is running under the context of aspnet_compiler.exe (where it will betrue), or at runtime (where it will befalse).InClientBuildManageralso applies to building a web site within VS, which uses basically the same code path as aspnet_compiler.exe.Try using PostStart methods instead
Note that WebActivator also supports
PostApplicationStartMethod, and those will not run under aspnet_compiler. That code runs afterApplication_Start, so it may or may not be appropriate to your scenario. But it may be a solution for you.aspnet_compiler.exe Debugging tip
Not directly related but useful for debugging: you can pass -errorstack to aspnet_compiler.exe to get a more complete stack when there is an error.