Created attachment 7070 [details]
This is a new report for the old bug 17936 to provide an up-to-date starting point, a test case, and information about workarounds.
## Steps to reproduce
1. Build the attached test case in Visual Studio, and run it on an iOS device.
2. Tap the "Click me" button.
> Unhandled managed exception: Operation is not valid due to the current state of the object (System.InvalidOperationException)
> at System.Lightup.Call[HttpWebRequest,Int64] (System.Delegate& storage, System.Net.HttpWebRequest instance, System.String methodName, Int64 parameter) [0x00000] in <filename unknown>:0
> at System.Lightup.Set[HttpWebRequest,Int64] (System.Delegate& storage, System.Net.HttpWebRequest instance, System.String propertyName, Int64 value) [0x00000] in <filename unknown>:0
> at System.Net.HttpWebRequestLightup.SetContentLength (System.Net.HttpWebRequest instance, Int64 value) [0x00000] in <filename unknown>:0
> at System.Net.Http.HttpWebRequest.set_ContentLength (Int64 value) [0x00000] in <filename unknown>:0
> at System.Net.Http.HttpClientHandler.StartRequest (System.Object obj) [0x00000] in <filename unknown>:0
> --- End of stack trace from previous location where exception was thrown ---
> at System.Runtime.ExceptionServices.ExceptionDis
> patchInfo.Throw () [0x0000b] in /Developer/MonoTouch/Source/mono/mcs/class/corlib/System.Runtime.ExceptionServices/ExceptionDispatchInfo.cs:62
> at System.Runtime.CompilerServices.TaskAwaiter`1[System.String].GetResult () [0x00000] in <filename unknown>:0
> at HttpAsyncTest.MyViewController+<<ViewDidLoad>b__0>d__2.MoveNext () [0x0001b] in c:\Users\%USERNAME%\Desktop\HttpNugetTest\HttpAsyncTest\MyViewController.cs:39
## Expected result
No exception, and the HTML content from www.example.com gets printed via `Console.WriteLine()`.
Follow the steps under "Close to the finish line" on . Optionally, change the "newVersion" to "220.127.116.11". Or simply add the attached `app.config` to the HttpAsyncTest project. This `app.config` redirects all versions of `System.Net.Http` so that the final app will contain the Xamarin.iOS assembly rather than the NuGet version.
>  http://motzcod.es/post/78863496592/portable-class-libraries-httpclient-so-happy
If you set "newVersion" to "18.104.22.168", the exception will return.
## Alternative workaround
In the "HttpAsyncLibrary" project, set the "CopyLocal" property for the "System.Net.Http" assembly to "False".
## Additional information
The assembly version number of System.Net.Http was recently changed to 22.214.171.124:
Unfortunately, at least for this particular test case, it appears that the NuGet package causes the app project to request the "126.96.36.199" NuGet version of the assembly. As a result, the final app bundle still contains the NuGet version instead of the Xamarin.iOS version:
> monodis --assembly ~/Library/Caches/Xamarin/mtbs/builds/HttpAsyncTest/2e353ad7-5ee3-4944-89f6-e5ba1c15178f/output/Debug/iPhone/HttpAsyncTest.app/System.Net.Http.dll | grep version
> Version: 188.8.131.52
## Version information
Note 1: the app runs without error when built and launched from Xamarin Studio on Mac.
Note 2: to workaround the XamarinVS 3.1 SDK sync bug #20588, I manually copied the assemblies from Xamarin.iOS 184.108.40.206 to the Windows side.
OS X 10.9.3
Microsoft Visual Studio Professional 2013
Version 12.0.30501.00 Update 2
Microsoft .NET Framework
Xamarin 220.127.116.11 (fb9b274179eab7ecc4c6ff10f9f7b789efe5b7f6)
Windows 8.1 64-bit (in VMWare)
Created attachment 7071 [details]
App.config for workaround
*** Bug 17936 has been marked as a duplicate of this bug. ***
I tried this issue and with the help of bug description I am able to reproduce this issue.
Steps to reproduce:
1. Open the attached project in VS 2013
2. Build and deploy the project on device.
3. Click on "Click Me" button.
4. An "Unhandled managed exception" will be thrown.
When I press "Click Me" button on device I observed that I am also getting an "Unhandled managed exception".
I have also tried the workaround as mentioned on bug description. I have added the attached app.config file on "HttpAsyncTest" project. Which contains the new version "18.104.22.168". I am not getting any exception and on the debug window it show "HTML" content, but when I changed the new version to "22.214.171.124" I am getting the same exception.
Debug logs: https://gist.github.com/anonymous/8bb172e96449c3397080
Microsoft Visual Studio Professional 2013
Version 12.0.21005.1 REL
Microsoft .NET Framework
Xamarin 126.96.36.199 (d3cf238e3845e930e312b6ec9b4c6c5437c33067)
Visual Studio extension to enable development for Xamarin.iOS and Xamarin.Android
Xamarin.iOS 188.8.131.52 (d3cf238e3845e930e312b6ec9b4c6c5437c33067)
Visual Studio extension to enable development for Xamarin.iOS
Xamarin.iOS Build Host: 184.108.40.206
This problem can also appear as the following exception:
> System.NotSupportedException: HttpClientHandler.PreAuthenticate is not supported on this platform. Please check HttpClientHandler.SupportsPreAuthenticate() before using HttpClientHandler.PreAuthenticate.
> at System.Net.Http.HttpWebRequest.set_PreAuthenticate (Boolean value) [0x00000] in <filename unknown>:0
> at System.Net.Http.HttpClientHandler.SetDefaultOptions (System.Net.Http.HttpWebRequest webRequest) [0x00000] in <filename unknown>:0
> at System.Net.Http.HttpClientHandler.CreateAndPrepareWebRequest (System.Net.Http.HttpRequestMessage request) [0x00000] in <filename unknown>:0
> at System.Net.Http.HttpClientHandler.SendAsync (System.Net.Http.HttpRequestMessage request, CancellationToken cancellationToken) [0x00000] in <filename unknown>:0
The same `app.config` workaround solves that exception too.
Closing this bug as By-Design.
The way that PCL's currently work in the presence of platform specific implementations, requires that the native app also installs the NuGet package.
Here's a good explanation of how PCL's should work in different scenarios, including this particular one: http://blogs.msdn.com/b/dsplaisted/archive/2012/08/27/how-to-make-portable-class-libraries-work-for-you.aspx
The RX assemblies uses the same approach. See the RX team blog post in turn for another case that's very well documented: http://blogs.msdn.com/b/rxteam/archive/2012/08/15/reactive-extensions-v2-0-has-arrived.aspx
Microsoft is aware of this issue, and the plan is to solve this for good in the next version of the platform.
As per Comment#7 changing the status to Verified.
I am having this exact issue with the simplest app ever. I am simply performing a single POST with httpclient. I don't see a good descriptive fix here.
by the way, everything is updated...Xamarin, all Nuget Packages, etc
To apply comment 7 to the specific test case that is attached to comment 0, the correct intended way to solve the problem is to install the "Microsoft HTTP Client Libraries" NuGet package into the "HttpAsyncTest" iOS _app project_ in addition to having it installed in the "HttpAsyncLibrary" PCL project.
This is the intended way to use NuGet PCL libraries that contain platform-specific code. (And the "Microsoft HTTP Client Libraries" NuGet _does_ include platform-specific code.)
In case it's helpful as an additional example, ModernHttpClient  has this same requirement because it also contains platform-specific code: the NuGet package must be installed into both the PCL library dependencies _and_ the app project that uses the dependencies. (See also  for more related discussion.)