I'm getting 'Catastrophic failure(Exception HRESULT: 0x8000FFFF (E_UNEXPECTED))' run-time error while trying to use MS WebView2 in ASP.NET Web API in production environment (Win10, IIS v.20H2 (OS Build 19042, 1586)) - see details in the code inline.

When the same code is used in a .NET Framework console app or under VS2019/Kestrel(?) (Ctrl+F5 - Start without debugging) everything works well.

private ManualResetEvent _event;
public void StartBrowserThread()
{ 
   var th = new Thread(async () =>
   { 
     BrowserFormsLogger.Log($"th.Context = {contextDescription}");

     var webView = new Microsoft.Web.WebView2.WinForms.WebView2();
 ...
     udf = ...
     var envTask = await Microsoft.Web.WebView2.Core.CoreWebView2Environment
                           .CreateAsync(userDataFolder: udf);

     var ecwTask = webView.EnsureCoreWebView2Async(envTask);
     while (ecwTask.IsCompleted == false)
     {
       Application.DoEvents();
       //
       // Run-time error happens here in ASP.NET environment after .DoEvents called several thousand times. 
       // In a .NET Framework Console App everything works well.
       // 
       // WebView2 creation failed with exception = System.Runtime.InteropServices.COMException (0x8000FFFF): 
       //   Catastrophic failure(Exception HRESULT: 0x8000FFFF (E_UNEXPECTED))
       //    in System.Runtime.InteropServices.Marshal.ThrowExceptionForHRInternal(Int32 errorCode, IntPtr errorInfo)
       //    in Microsoft.Web.WebView2.Core.CoreWebView2Environment.<CreateCoreWebView2ControllerAsync>d__58.MoveNext()
       // --- End of stack trace from previous location where exception occurred ---
       //    in System.Runtime.CompilerServices.TaskAwaiter.ThrowForNonSuccess(Task task)
       //    in System.Runtime.CompilerServices.TaskAwaiter.HandleNonSuccessAndDebuggerNotification(Task task)
       //    in System.Runtime.CompilerServices.TaskAwaiter.ValidateEnd(Task task)
       //    in Microsoft.Web.WebView2.WinForms.WebView2.<InitCoreWebView2Async>d__18.MoveNext()
     };
     ...
     _event.Set();

     System.Windows.Forms.Application.Run();

  });


  th.SetApartmentState(ApartmentState.STA);
  th.IsBackground  = true;
  _event = new ManualResetEvent(false);
  th.Start();

...

Any clues how this issue can be solved?

0

There are 0 best solutions below