Thursday, January 19, 2006
« Go Live licenses for WCF and WF | Main | MIX 06 - Microsoft Web Conference »

In a previous post I discussed some issues I’ve been having with the ASP.NET Development Server (aka VS Host or Cassini).

 

I have more information direct from Microsoft on my issue. It turns out that it is “by design”, and a sad thing this is… VS Host is designed such that the thread on which your code runs can (and does) go between AppDomains.

 

Objects placed on the Thread object, such as the CurrentPrincipal, must be serializable and the assembly must be available to all AppDomains; even the primary AppDomain that isn’t running as part of your web site!

 

And this is the root of my problem. I create a custom IPrincipal object in an assembly (dll). I put it in the Bin directory and then use it – which of course means it ends up on the Thread object. Cassini then runs my code in an AppDomain for my web site and all is well until it switches out into another AppDomain that isn’t running my web site (but rather is just running Cassini itself). Boom!

 

Why boom? Well, that custom IPrincipal object on the thread is still on the thread. When the thread switches to the other AppDomain, objects directly attached to the thread (like CurrentPrincipal) are automatically serialized, the byte stream transferred to the new AppDomain, and deserialized into the new AppDomain. This means that the new AppDomain must have access to the assembly containing the custom IPrincipal class – but of course it doesn’t, because it isn’t running as part of the web site and thus doesn’t have access to the Bin directory.

 

What’s the answer? Either don’t use Cassini (which has been my answer), or install the assembly with the custom IPrincipal into the GAC. Technically the latter answer is the “right” one, but that has the ugly side-effect of preventing rapid application development. All of a sudden you can’t just change a bit of code and press F5 to test; instead you must build your code, update the GAC and then you can test. Nasty…

 

As an aside, this is exactly the same issue you’ll run into when using nunit to test code that uses a custom IPrincipal on the thread. Unlike nunit however, you can’t predict when Cassini will switch you to another AppDomain so you can’t work around the issue by clearing the CurrentPrincipal like you can with nunit (or at least I haven’t found the magic point at which to do it…).

 

What’s really scary is that it was implied that this could happen under IIS as well – but that flies in the face of years of experiential evidence to the contrary. I guess the safe thing to do is to treat IIS like Cassini, and put shared assemblies in the GAC. But I’m not sure I’m ready to advocate that yet, because that means complicating installs a whole lot, and I’ve never encountered this threading issue under IIS so I don’t think it is a real issue.

Thursday, January 19, 2006 9:34:17 AM (Central Standard Time, UTC-06:00)  #    Disclaimer  |  Comments [18]  |  Related posts:
My philosophy on using new technologies
Do you use VB late binding? If so, how?
Thoughts on MIX 08
ClickOnce and WFP publish failure (and solution)
Microsoft .NET and CSLA .NET version confusion
Visual Studio 2008 Beta 2 and .NET FX 3.5 Beta 2 are available now!
Tracked by:
"bay area photographer" (bay area photographer) [Trackback]
"maryland automotive windshield" (maryland automotive windshield) [Trackback]
"her first audition" (her first audition) [Trackback]
"annuncio affitti isernia" (annuncio affitti isernia) [Trackback]
"paul posey tallahassee florida" (paul posey tallahassee florida) [Trackback]
"sauna mista milano" (sauna mista milano) [Trackback]
"georgia bulldog" (georgia bulldog) [Trackback]
"cd organizers" (cd organizers) [Trackback]
"congelatore da incasso" (congelatore da incasso) [Trackback]
"cameriere in autoreggenti" (cameriere in autoreggenti) [Trackback]
"Sports Betting Rss Feed" (Sports Betting Rss Feed) [Trackback]
"albuquerque respiratory jobs va medical center" (albuquerque respiratory jobs v... [Trackback]
"tiaras and headpieces" (tiaras and headpieces) [Trackback]
"used kountry aire camper trailer" (used kountry aire camper trailer) [Trackback]
"columbus ohio commercial real estate" (columbus ohio commercial real estate) [Trackback]
"invisibile pulcino dildo" (invisibile pulcino dildo) [Trackback]
"fotografico" (fotografico) [Trackback]
"sms gratis cellulare" (sms gratis cellulare) [Trackback]
"racconto erotici con animali" (racconto erotici con animali) [Trackback]
"female body builders posing" (female body builders posing) [Trackback]
"zyban side affects" (zyban side affects) [Trackback]
"Socialist Appeal" (Socialist Appeal) [Trackback]
"Untitled Document" (Untitled Document) [Trackback]
"Over N Out. :: Index" (Over N Out. :: Index) [Trackback]
"Galaxy Portfolio Services" (Galaxy Portfolio Services) [Trackback]
"fuck that, fuck them, fuck everyone else." (fuck that, fuck them, fuck everyone... [Trackback]
http://www.setfirestudios.com/work.php [Trackback]
"4839_architectonic - Departurebanish.com" (4839_architectonic - Departurebanish... [Trackback]
http://www.setfirestudios.com/main.php [Trackback]
"Untitled Document" (Untitled Document) [Trackback]
"backsoon" (backsoon) [Trackback]
"halifest" (halifest) [Trackback]
"Baylor - Departurebanish.com" (Baylor - Departurebanish.com) [Trackback]
"Untitled Document" (Untitled Document) [Trackback]
"Running The Guard... NYHC" (Running The Guard... NYHC) [Trackback]
"4 < 9" (4 < 9) [Trackback]
"AlloyMail" (AlloyMail) [Trackback]
"Non-party - Departurebanish.com" (Non-party - Departurebanish.com) [Trackback]
"CHARA. reppin' pei" (CHARA. reppin' pei) [Trackback]
"8533 - Departurebanish.com" (8533 - Departurebanish.com) [Trackback]
"Erica Funghi Snc" (Erica Funghi Snc) [Trackback]
"2029_guiftes - Departurebanish.com" (2029_guiftes - Departurebanish.com) [Trackback]
"Law-unto-itself - Departurebanish.com" (Law-unto-itself - Departurebanish.com) [Trackback]
"Circumstances_8558 - Departurebanish.com" (Circumstances_8558 - Departurebanish... [Trackback]
"Deutsche Lebens Rettungs Gesellschaft eV (DLRG)" (Deutsche Lebens Rettungs Gese... [Trackback]
"Athenian_622 - Departurebanish.com" (Athenian_622 - Departurebanish.com) [Trackback]
"Suggestion_2469 - Departurebanish.com" (Suggestion_2469 - Departurebanish.com) [Trackback]
"Bus Pass" (Bus Pass) [Trackback]
"Visual Elements: The Alkaline Earth Metals" (Visual Elements: The Alkaline Eart... [Trackback]
"Departurebanish.com" (Departurebanish.com) [Trackback]
"She Kills dot com bitches." (She Kills dot com bitches.) [Trackback]
"Camera Whores!!!" (Camera Whores!!!) [Trackback]
"Untitled Document" (Untitled Document) [Trackback]
"Untitled Document" (Untitled Document) [Trackback]
"1471 - Departurebanish.com" (1471 - Departurebanish.com) [Trackback]
http://www.setfirestudios.com/contacts.php [Trackback]
"Untitled Document" (Untitled Document) [Trackback]
"electric tool accessories" (electric tool accessories) [Trackback]
"legal aid society" (legal aid society) [Trackback]
"posing stool" (posing stool) [Trackback]
"foto ose" (foto ose) [Trackback]
"second income ideas" (second income ideas) [Trackback]
"good looking idraulico" (good looking idraulico) [Trackback]
"alternative school programs" (alternative school programs) [Trackback]
"Force Outboard Motor Parts" (Force Outboard Motor Parts) [Trackback]
"hilo hawaii real estate" (hilo hawaii real estate) [Trackback]
"custom plaque drop ship" (custom plaque drop ship) [Trackback]
"snowmobile helmets" (snowmobile helmets) [Trackback]
"aol and vpn connections" (aol and vpn connections) [Trackback]
"fictional detectives" (fictional detectives) [Trackback]
"Kawasaki Ninja 250 Performance" (Kawasaki Ninja 250 Performance) [Trackback]
"enoteche" (enoteche) [Trackback]
"bakersfeild ca" (bakersfeild ca) [Trackback]
"panasonic plasma tv" (panasonic plasma tv) [Trackback]
"print manager software" (print manager software) [Trackback]
"ridiculous infermiera azione" (ridiculous infermiera azione) [Trackback]
"bitch island" (bitch island) [Trackback]
"chicago bbw escort" (chicago bbw escort) [Trackback]
"challenger gate garage door openers" (challenger gate garage door openers) [Trackback]
"building developers IN USA" (building developers IN USA) [Trackback]
"handbags and gladrags stereophonics" (handbags and gladrags stereophonics) [Trackback]
"Ford 56 F100 for Sale" (Ford 56 F100 for Sale) [Trackback]
"Santa Barbara Collection" (Santa Barbara Collection) [Trackback]
"bangkok train schedule" (bangkok train schedule) [Trackback]
"ford warranty" (ford warranty) [Trackback]
"Luggage Repair Parts %2B wheels" (Luggage Repair Parts %2B wheels) [Trackback]
"aspirin vs plavix" (aspirin vs plavix) [Trackback]
"real estate woodstock georgia" (real estate woodstock georgia) [Trackback]