#7024 Request: ServiceBasedPageModelActivatorProvider [Review Changes]
This commit is contained in:
parent
b8e5036e20
commit
077b1d87a9
|
|
@ -110,11 +110,9 @@ namespace Microsoft.Extensions.DependencyInjection
|
|||
ServiceDescriptor.Singleton<IActionInvokerProvider, PageActionInvokerProvider>());
|
||||
|
||||
// Page and Page model creation and activation
|
||||
services.TryAddSingleton<IPageModelActivatorProvider, DefaultPageModelActivatorProvider>();
|
||||
services.TryAddSingleton<IPageModelActivatorProvider, DefaultPageModelActivatorProvider>();
|
||||
services.TryAddSingleton<IPageModelFactoryProvider, DefaultPageModelFactoryProvider>();
|
||||
|
||||
services.TryAddSingleton<IPageModelActivatorProvider, ServiceBasedPageModelActivatorProvider>();
|
||||
|
||||
services.TryAddSingleton<IPageActivatorProvider, DefaultPageActivatorProvider>();
|
||||
services.TryAddSingleton<IPageFactoryProvider, DefaultPageFactoryProvider>();
|
||||
|
||||
|
|
|
|||
|
|
@ -19,8 +19,8 @@ namespace Microsoft.AspNetCore.Mvc.RazorPages.Infrastructure
|
|||
throw new ArgumentNullException(nameof(descriptor));
|
||||
}
|
||||
|
||||
var modelTypeInfo = descriptor.ModelTypeInfo?.AsType();
|
||||
if (modelTypeInfo == null)
|
||||
var modelType = descriptor.ModelTypeInfo?.AsType();
|
||||
if (modelType == null)
|
||||
{
|
||||
throw new ArgumentException(Resources.FormatPropertyOfTypeCannotBeNull(
|
||||
nameof(descriptor.ModelTypeInfo),
|
||||
|
|
@ -30,7 +30,7 @@ namespace Microsoft.AspNetCore.Mvc.RazorPages.Infrastructure
|
|||
|
||||
return context =>
|
||||
{
|
||||
return context.HttpContext.RequestServices.GetRequiredService(modelTypeInfo);
|
||||
return context.HttpContext.RequestServices.GetRequiredService(modelType);
|
||||
};
|
||||
}
|
||||
|
||||
|
|
|
|||
|
|
@ -31,10 +31,10 @@ namespace Microsoft.AspNetCore.Mvc.RazorPages.Infrastructure
|
|||
{
|
||||
// Arrange
|
||||
var simpleModel = new DISimpleModel();
|
||||
var serviceProvider = new Mock<IServiceProvider>(MockBehavior.Strict);
|
||||
var serviceProvider = new Mock<IServiceProvider>(MockBehavior.Strict);
|
||||
serviceProvider.Setup(s => s.GetService(typeof(DISimpleModel)))
|
||||
.Returns(simpleModel)
|
||||
.Verifiable();
|
||||
.Returns(simpleModel)
|
||||
.Verifiable();
|
||||
|
||||
var activatorProvider = new ServiceBasedPageModelActivatorProvider();
|
||||
var pageContext = new PageContext
|
||||
|
|
@ -62,11 +62,11 @@ namespace Microsoft.AspNetCore.Mvc.RazorPages.Infrastructure
|
|||
public void CreateActivator_CreatesModelInstance()
|
||||
{
|
||||
// Arrange
|
||||
var controller = new DISimpleModel();
|
||||
var simpleModel = new DISimpleModel();
|
||||
var serviceProvider = new Mock<IServiceProvider>(MockBehavior.Strict);
|
||||
serviceProvider.Setup(s => s.GetService(typeof(DISimpleModel)))
|
||||
.Returns(controller)
|
||||
.Verifiable();
|
||||
.Returns(simpleModel)
|
||||
.Verifiable();
|
||||
|
||||
var activatorProvider = new ServiceBasedPageModelActivatorProvider();
|
||||
var pageContext = new PageContext
|
||||
|
|
@ -86,8 +86,8 @@ namespace Microsoft.AspNetCore.Mvc.RazorPages.Infrastructure
|
|||
var model = activator(pageContext);
|
||||
|
||||
// Assert
|
||||
var simpleModel = Assert.IsType<DISimpleModel>(model);
|
||||
Assert.NotNull(simpleModel);
|
||||
var simpleModel2 = Assert.IsType<DISimpleModel>(model);
|
||||
Assert.NotNull(simpleModel2);
|
||||
}
|
||||
|
||||
[Fact]
|
||||
|
|
|
|||
Loading…
Reference in New Issue