Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Update dependencies and workaround dotnet/sdk#2976 #7844

Merged
merged 11 commits into from
Feb 23, 2019

Conversation

natemcmaster
Copy link
Contributor

Opened manually using our script that finds coherent dependencies

@natemcmaster natemcmaster requested a review from dougbu as a code owner February 22, 2019 05:01
@benaadams
Copy link
Member

Components/Blazor/Blazor/test/Hosting/WebAssemblyHostTest.cs(65,63):
 error CS0117: 'JSRuntime' does not contain a definition for 'Current'
 [/home/vsts/work/1/s/src/Components/Blazor/Blazor/test/Microsoft.AspNetCore.Blazor.Tests.csproj]
Components/Blazor/testassets/Microsoft.AspNetCore.Blazor.E2EPerformance/BenchmarkEvent.cs(12,45):
 error CS0117: 'JSRuntime' does not contain a definition for 'Current' [/home/vsts/work/1/s/src/Components/Blazor/testassets/Microsoft.AspNetCore.Blazor.E2EPerformance/Microsoft.AspNetCore.Blazor.E2EPerformance.csproj]

@natemcmaster
Copy link
Contributor Author

@pranavkm handing the mic to you. Can you update this repo to react to dotnet/extensions#1118?

cc @rynowak @SteveSandersonMS

@pranavkm
Copy link
Contributor

/azp run AspNetCore-ci

@azure-pipelines
Copy link

Azure Pipelines successfully started running 1 pipeline(s).

@benaadams
Copy link
Member

benaadams commented Feb 22, 2019

Back to LoggerFactory being disposed (368 Failed tests)

 System.ObjectDisposedException: Cannot access a disposed object.
  Object name: 'LoggerFactory'.
     at Microsoft.Extensions.Logging.LoggerFactory.CreateLogger(String categoryName)
     at Microsoft.EntityFrameworkCore.Internal.ExternalLoggerFactory.CreateLogger(String categoryName)
     at Microsoft.EntityFrameworkCore.Internal.DiagnosticsLogger`1..ctor(ILoggerFactory loggerFactory, ILoggingOptions loggingOptions, DiagnosticSource diagnosticSource)
     at ResolveService(ILEmitResolverBuilderRuntimeContext , ServiceProviderEngineScope )
     at ResolveService(ILEmitResolverBuilderRuntimeContext , ServiceProviderEngineScope )
     at ResolveService(ILEmitResolverBuilderRuntimeContext , ServiceProviderEngineScope )
     at Microsoft.Extensions.DependencyInjection.ServiceProviderServiceExtensions.GetRequiredService(IServiceProvider provider, Type serviceType)
     at Microsoft.Extensions.DependencyInjection.ServiceProviderServiceExtensions.GetRequiredService[T](IServiceProvider provider)
     at Microsoft.EntityFrameworkCore.DbContext.get_DbContextDependencies()
     at Microsoft.EntityFrameworkCore.DbContext.get_InternalServiceProvider()
     at Microsoft.EntityFrameworkCore.DbContext.get_DbContextDependencies()
     at Microsoft.EntityFrameworkCore.DbContext.Set[TEntity]()
     at Microsoft.AspNetCore.Identity.EntityFrameworkCore.UserStore`9.get_UsersSet() in /_/src/Identity/EntityFrameworkCore/src/UserStore.cs:line 128
     at Microsoft.AspNetCore.Identity.EntityFrameworkCore.UserStore`9.get_Users() in /_/src/Identity/EntityFrameworkCore/src/UserStore.cs:line 262
     at Microsoft.AspNetCore.Identity.EntityFrameworkCore.UserStore`9.FindByNameAsync(String normalizedUserName, CancellationToken cancellationToken) in /_/src/Identity/EntityFrameworkCore/src/UserStore.cs:line 254
     at Microsoft.AspNetCore.Identity.UserManager`1.FindByNameAsync(String userName) in /_/src/Identity/Extensions.Core/src/UserManager.cs:line 573
     at Microsoft.AspNetCore.Identity.UserValidator`1.ValidateUserName(UserManager`1 manager, TUser user, ICollection`1 errors) in /_/src/Identity/Extensions.Core/src/UserValidator.cs:line 79
     at Microsoft.AspNetCore.Identity.UserValidator`1.ValidateAsync(UserManager`1 manager, TUser user) in /_/src/Identity/Extensions.Core/src/UserValidator.cs:line 56
     at Microsoft.AspNetCore.Identity.UserManager`1.ValidateUserAsync(TUser user) in /_/src/Identity/Extensions.Core/src/UserManager.cs:line 2494
     at Microsoft.AspNetCore.Identity.UserManager`1.CreateAsync(TUser user) in /_/src/Identity/Extensions.Core/src/UserManager.cs:line 470
     at Microsoft.AspNetCore.Identity.UserManager`1.CreateAsync(TUser user, String password) in /_/src/Identity/Extensions.Core/src/UserManager.cs:line 602
     at Microsoft.AspNetCore.Identity.UI.V3.Pages.Account.Internal.RegisterModel`1.OnPostAsync(String returnUrl) in /_/src/Identity/UI/src/Areas/Identity/Pages/V3/Account/Register.cshtml.cs:line 125
     at Microsoft.AspNetCore.Mvc.RazorPages.Infrastructure.ExecutorFactory.GenericTaskHandlerMethod.Convert[T](Object taskAsObject) in /_/src/Mvc/Mvc.RazorPages/src/Infrastructure/ExecutorFactory.cs:line 145
     at Microsoft.AspNetCore.Mvc.RazorPages.Infrastructure.ExecutorFactory.GenericTaskHandlerMethod.Execute(Object receiver, Object[] arguments) in /_/src/Mvc/Mvc.RazorPages/src/Infrastructure/ExecutorFactory.cs:line 139
     at Microsoft.AspNetCore.Mvc.RazorPages.Infrastructure.PageActionInvoker.InvokeHandlerMethodAsync() in /_/src/Mvc/Mvc.RazorPages/src/Infrastructure/PageActionInvoker.cs:line 288
     at Microsoft.AspNetCore.Mvc.RazorPages.Infrastructure.PageActionInvoker.InvokeNextPageFilterAsync() in /_/src/Mvc/Mvc.RazorPages/src/Infrastructure/PageActionInvoker.cs:line 654
     at Microsoft.AspNetCore.Mvc.RazorPages.Infrastructure.PageActionInvoker.Rethrow(PageHandlerExecutedContext context) in /_/src/Mvc/Mvc.RazorPages/src/Infrastructure/PageActionInvoker.cs:line 696
     at Microsoft.AspNetCore.Mvc.RazorPages.Infrastructure.PageActionInvoker.Next(State& next, Scope& scope, Object& state, Boolean& isCompleted) in /_/src/Mvc/Mvc.RazorPages/src/Infrastructure/PageActionInvoker.cs:line 628
     at Microsoft.AspNetCore.Mvc.RazorPages.Infrastructure.PageActionInvoker.InvokeInnerFilterAsync() in /_/src/Mvc/Mvc.RazorPages/src/Infrastructure/PageActionInvoker.cs:line 93
     at Microsoft.AspNetCore.Mvc.Infrastructure.ResourceInvoker.InvokeNextResourceFilter() in /_/src/Mvc/Mvc.Core/src/Infrastructure/ResourceInvoker.cs:line 809
     at Microsoft.AspNetCore.Mvc.Infrastructure.ResourceInvoker.Rethrow(ResourceExecutedContext context) in /_/src/Mvc/Mvc.Core/src/Infrastructure/ResourceInvoker.cs:line 1153
     at Microsoft.AspNetCore.Mvc.Infrastructure.ResourceInvoker.Next(State& next, Scope& scope, Object& state, Boolean& isCompleted) in /_/src/Mvc/Mvc.Core/src/Infrastructure/ResourceInvoker.cs:line 762
     at Microsoft.AspNetCore.Mvc.Infrastructure.ResourceInvoker.InvokeFilterPipelineAsync() in /_/src/Mvc/Mvc.Core/src/Infrastructure/ResourceInvoker.cs:line 129
     at Microsoft.AspNetCore.Mvc.Infrastructure.ResourceInvoker.InvokeAsync() in /_/src/Mvc/Mvc.Core/src/Infrastructure/ResourceInvoker.cs:line 101
     at Microsoft.AspNetCore.Routing.EndpointMiddleware.Invoke(HttpContext httpContext) in /_/src/Http/Routing/src/EndpointMiddleware.cs:line 53
     at Microsoft.AspNetCore.Routing.EndpointRoutingMiddleware.Invoke(HttpContext httpContext) in /_/src/Http/Routing/src/EndpointRoutingMiddleware.cs:line 79
     at Microsoft.AspNetCore.Authentication.AuthenticationMiddleware.Invoke(HttpContext context) in /_/src/Security/Authentication/Core/src/AuthenticationMiddleware.cs:line 62

Could "Make ILoggerFactory a scoped service" dotnet/efcore#14706 have caused the disposal? /cc @ajcvickers

e.g.

-  { typeof(ILoggerFactory), new ServiceCharacteristics(ServiceLifetime.Singleton) },
+  { typeof(ILoggerFactory), new ServiceCharacteristics(ServiceLifetime.Scoped) },

Or perhaps

- services.AddSingleton(loggerFactory);
+ services.AddScoped<ILoggerFactory>(_ => new ExternalLoggerFactory(loggerFactory));

Perhaps is causing both ILoggerFactory's to get disposed? dotnet/extensions#1155 (or maybe there is only the scoped one and its used out of scope?)

@benaadams
Copy link
Member

Most of the 368 failed tests tests are under Microsoft.AspNetCore.Identity.FunctionalTests

Couple in Microsoft.Extensions.Diagnostics.HealthChecks.DbContextHealthCheckTest which seem different

@natemcmaster natemcmaster assigned ajcvickers and unassigned pranavkm Feb 22, 2019
@ajcvickers
Copy link
Contributor

In have a PR out to fix EF: dotnet/efcore#14783

@natemcmaster natemcmaster added blocked The work on this issue is blocked due to some dependency area-infrastructure Includes: MSBuild projects/targets, build scripts, CI, Installers and shared framework labels Feb 22, 2019
Copy link
Member

@dougbu dougbu left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Once we have the newer EF Core and the builds turn green :shipit:

</Dependency>
<Dependency Name="Microsoft.AspNetCore.Testing" Version="3.0.0-preview3.19115.4">
<Dependency Name="Microsoft.AspNetCore.Testing" Version="3.0.0-preview3.19120.1">
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Strange that this update doesn't cause restore failures (version downgrade errors) -- as is happening in AspNetCore-Tooling. Recent versions of this package depend on newer Xunit versions than in this repo. 2.4.0 is the magic number.

Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

This repo is already using xunit 2.4.0. I think aspnetcore-tooling was the only one still on 2.3

@natemcmaster
Copy link
Contributor Author

Pushed a change to react to dotnet/razor#240, dotnet/efcore#14790, and dotnet/extensions#1159

@benaadams
Copy link
Member

Not sure it has the new EF stuff yet?

       An unhandled exception has occurred while executing the request.
  System.ObjectDisposedException: Cannot access a disposed object.
  Object name: 'LoggerFactory'.
     at Microsoft.Extensions.Logging.LoggerFactory.CreateLogger(String categoryName)
     at Microsoft.EntityFrameworkCore.Internal.ExternalLoggerFactory.CreateLogger(String categoryName)
     at Microsoft.EntityFrameworkCore.Internal.DiagnosticsLogger`1..ctor(ILoggerFactory loggerFactory, ILoggingOptions loggingOptions, DiagnosticSource diagnosticSource)
     at ResolveService(ILEmitResolverBuilderRuntimeContext , ServiceProviderEngineScope )
     at ResolveService(ILEmitResolverBuilderRuntimeContext , ServiceProviderEngineScope )
     at ResolveService(ILEmitResolverBuilderRuntimeContext , ServiceProviderEngineScope )
     at Microsoft.Extensions.DependencyInjection.ServiceProviderServiceExtensions.GetRequiredService(IServiceProvider provider, Type serviceType)
     at Microsoft.Extensions.DependencyInjection.ServiceProviderServiceExtensions.GetRequiredService[T](IServiceProvider provider)
     at Microsoft.EntityFrameworkCore.DbContext.get_DbContextDependencies()
     at Microsoft.EntityFrameworkCore.DbContext.get_InternalServiceProvider()
     at Microsoft.EntityFrameworkCore.DbContext.get_DbContextDependencies()
     at Microsoft.EntityFrameworkCore.DbContext.Set[TEntity]()

@dougbu
Copy link
Member

dougbu commented Feb 22, 2019

@benaadams no it doesn't. @natemcmaster could you rerun your tool please?

@natemcmaster
Copy link
Contributor Author

Updated with latest EFCore. 🤞

@benaadams
Copy link
Member

MVC using its own obsolete method?

/home/vsts/work/1/s/src/Mvc/Mvc.Localization/src/HtmlLocalizer.cs(95,38):

 error CS0618: 'IStringLocalizer.WithCulture(CultureInfo)' is obsolete:
 'This method is obsolete. Use `CurrentCulture` and `CurrentUICulture` instead.' 
[/home/vsts/work/1/s/src/Mvc/Mvc.Localization/src/Microsoft.AspNetCore.Mvc.Localization.csproj]

@natemcmaster
Copy link
Contributor Author

@ryanbrandenburg can you update AspNetCore to react to change you made in Extensions?

@benaadams
Copy link
Member

Restart Build Linux x64; was a docker registry timeout

Step 1/12 : FROM microsoft/dotnet:2.1-runtime-deps-bionic
Get https://registry-1.docker.io/v2/: net/http: TLS handshake timeout
##[error]Bash exited with code '1'.

@benaadams
Copy link
Member

macOs failure

Microsoft.Extensions.Diagnostics.HealthChecks.DbContextHealthCheckTest.CheckAsync_CustomTest_Unhealthy
Assert.Equal() Failure
Expected: Unhealthy
Actual: Healthy

Stack trace
   at Microsoft.Extensions.Diagnostics.HealthChecks.DbContextHealthCheckTest.CheckAsync_CustomTest_Unhealthy() in /_/src/Middleware/HealthChecks.EntityFrameworkCore/test/DbContextHealthCheckTest.cs:line 103
--- End of stack trace from previous location where exception was thrown ---

@natemcmaster
Copy link
Contributor Author

Getting closer. The ILoggerFactory test failures and compiler errors are gone.

Next failure:

  Failed   Microsoft.Extensions.Diagnostics.HealthChecks.DbContextHealthCheckTest.CheckAsync_CustomTest_Unhealthy
  Error Message:
   Assert.Equal() Failure
  Expected: Unhealthy
  Actual:   Healthy

@Tratcher @rynowak any ideas?

@ajcvickers
Copy link
Contributor

@natemcmaster @Tratcher @rynowak I don't have time to investigate right now, but ping me if the DbContextHealthCheck looks like it is caused by EF changes.

@natemcmaster
Copy link
Contributor Author

There's a more than good chance the failure is due to EFCore. The health checks stuff hasn't changed recently. I'll take a look at the test to see if the test makes bad assumptions about EFCore and service scopes.

@natemcmaster
Copy link
Contributor Author

@natemcmaster
Copy link
Contributor Author

@ajcvickers @rynowak - workaround for changes in EF in-memory database behavior:

aaaecbf

@rynowak
Copy link
Member

rynowak commented Feb 23, 2019

Looks fine, a comment would make it mo better.

@natemcmaster natemcmaster removed the blocked The work on this issue is blocked due to some dependency label Feb 23, 2019
@natemcmaster natemcmaster merged commit 1b27c99 into release/3.0-preview3 Feb 23, 2019
@natemcmaster natemcmaster deleted the namc/update branch February 23, 2019 03:09
@ajcvickers
Copy link
Contributor

@natemcmaster @rynowak Thanks Nate. Here's what's happening. When an in-memory database with a specific name is used, that database is under normal circumstances supposed to be the same database later if the same name is used. However, in reality the named database is rooted by default in EF's internal service provider. So the above behavior holds true as long as the same internal service provider is used by EF, which for a given EF configuration should be true.

So this behavior that is now being seen in these tests--when a database called "Test" is used it is shared by all tests that create a database with that name. This is as things are supposed to be, and is one of the things that the EF breaking change makes "better". (The reason for this is that previously anytime a new ILoggerFactory was used with each DbContext instance, it caused EF to build a new internal service provider for that DbContext instance. (This is easy to hit in ASP.NET tests that often create a new ILoggerFactory for each test.) This no longer happens, so all the tests use the same EF internal service provider, which means they get to share the in-memory database.)

In this case, the tests were dependent on the old behavior. So this is a case where the breaking change really broke things, but in an expected way, and with ultimately better, more consistent behavior. Still we should make sure it's documented. /cc @divega

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
area-infrastructure Includes: MSBuild projects/targets, build scripts, CI, Installers and shared framework
Projects
None yet
Development

Successfully merging this pull request may close these issues.

7 participants