#265 Remove Use extensions that take services.
This commit is contained in:
parent
f7f4d490aa
commit
550b2252ea
|
|
@ -26,125 +26,5 @@ namespace Microsoft.AspNet.Builder
|
||||||
};
|
};
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
/// <summary>
|
|
||||||
/// Use middleware defined in-line
|
|
||||||
/// </summary>
|
|
||||||
/// <typeparam name="TService1">Per-request service required by middleware</typeparam>
|
|
||||||
/// <param name="app"></param>
|
|
||||||
/// <param name="middleware">A function that handles the request or calls the given next function.</param>
|
|
||||||
/// <returns></returns>
|
|
||||||
public static IApplicationBuilder Use<TService1>(this IApplicationBuilder app, Func<HttpContext, Func<Task>, TService1, Task> middleware)
|
|
||||||
{
|
|
||||||
var applicationServices = app.ApplicationServices;
|
|
||||||
return app.Use(next => context =>
|
|
||||||
{
|
|
||||||
var serviceProvider = context.RequestServices ?? context.ApplicationServices ?? applicationServices;
|
|
||||||
if (serviceProvider == null)
|
|
||||||
{
|
|
||||||
throw new Exception("TODO: IServiceProvider is not available");
|
|
||||||
}
|
|
||||||
return middleware(
|
|
||||||
context,
|
|
||||||
() => next(context),
|
|
||||||
GetRequiredService<TService1>(serviceProvider));
|
|
||||||
});
|
|
||||||
}
|
|
||||||
|
|
||||||
/// <summary>
|
|
||||||
/// Use middleware defined in-line
|
|
||||||
/// </summary>
|
|
||||||
/// <typeparam name="TService1">Per-request service required by middleware</typeparam>
|
|
||||||
/// <typeparam name="TService2">Per-request service required by middleware</typeparam>
|
|
||||||
/// <param name="app"></param>
|
|
||||||
/// <param name="middleware">A function that handles the request or calls the given next function.</param>
|
|
||||||
/// <returns></returns>
|
|
||||||
public static IApplicationBuilder Use<TService1, TService2>(this IApplicationBuilder app, Func<HttpContext, Func<Task>, TService1, TService2, Task> middleware)
|
|
||||||
{
|
|
||||||
var applicationServices = app.ApplicationServices;
|
|
||||||
return app.Use(next => context =>
|
|
||||||
{
|
|
||||||
var serviceProvider = context.RequestServices ?? context.ApplicationServices ?? applicationServices;
|
|
||||||
if (serviceProvider == null)
|
|
||||||
{
|
|
||||||
throw new Exception("TODO: IServiceProvider is not available");
|
|
||||||
}
|
|
||||||
return middleware(
|
|
||||||
context,
|
|
||||||
() => next(context),
|
|
||||||
GetRequiredService<TService1>(serviceProvider),
|
|
||||||
GetRequiredService<TService2>(serviceProvider));
|
|
||||||
});
|
|
||||||
}
|
|
||||||
|
|
||||||
/// <summary>
|
|
||||||
/// Use middleware defined in-line
|
|
||||||
/// </summary>
|
|
||||||
/// <typeparam name="TService1">Per-request service required by middleware</typeparam>
|
|
||||||
/// <typeparam name="TService2">Per-request service required by middleware</typeparam>
|
|
||||||
/// <typeparam name="TService3">Per-request service required by middleware</typeparam>
|
|
||||||
/// <param name="app"></param>
|
|
||||||
/// <param name="middleware">A function that handles the request or calls the given next function.</param>
|
|
||||||
/// <returns></returns>
|
|
||||||
public static IApplicationBuilder Use<TService1, TService2, TService3>(this IApplicationBuilder app, Func<HttpContext, Func<Task>, TService1, TService2, TService3, Task> middleware)
|
|
||||||
{
|
|
||||||
var applicationServices = app.ApplicationServices;
|
|
||||||
return app.Use(next => context =>
|
|
||||||
{
|
|
||||||
var serviceProvider = context.RequestServices ?? context.ApplicationServices ?? applicationServices;
|
|
||||||
if (serviceProvider == null)
|
|
||||||
{
|
|
||||||
throw new Exception("TODO: IServiceProvider is not available");
|
|
||||||
}
|
|
||||||
return middleware(
|
|
||||||
context,
|
|
||||||
() => next(context),
|
|
||||||
GetRequiredService<TService1>(serviceProvider),
|
|
||||||
GetRequiredService<TService2>(serviceProvider),
|
|
||||||
GetRequiredService<TService3>(serviceProvider));
|
|
||||||
});
|
|
||||||
}
|
|
||||||
|
|
||||||
/// <summary>
|
|
||||||
/// Use middleware defined in-line
|
|
||||||
/// </summary>
|
|
||||||
/// <typeparam name="TService1">Per-request service required by middleware</typeparam>
|
|
||||||
/// <typeparam name="TService2">Per-request service required by middleware</typeparam>
|
|
||||||
/// <typeparam name="TService3">Per-request service required by middleware</typeparam>
|
|
||||||
/// <typeparam name="TService4">Per-request service required by middleware</typeparam>
|
|
||||||
/// <param name="app"></param>
|
|
||||||
/// <param name="middleware">A function that handles the request or calls the given next function.</param>
|
|
||||||
/// <returns></returns>
|
|
||||||
public static IApplicationBuilder Use<TService1, TService2, TService3, TService4>(this IApplicationBuilder app, Func<HttpContext, Func<Task>, TService1, TService2, TService3, TService4, Task> middleware)
|
|
||||||
{
|
|
||||||
var applicationServices = app.ApplicationServices;
|
|
||||||
return app.Use(next => context =>
|
|
||||||
{
|
|
||||||
var serviceProvider = context.RequestServices ?? context.ApplicationServices ?? applicationServices;
|
|
||||||
if (serviceProvider == null)
|
|
||||||
{
|
|
||||||
throw new Exception("TODO: IServiceProvider is not available");
|
|
||||||
}
|
|
||||||
return middleware(
|
|
||||||
context,
|
|
||||||
() => next(context),
|
|
||||||
GetRequiredService<TService1>(serviceProvider),
|
|
||||||
GetRequiredService<TService2>(serviceProvider),
|
|
||||||
GetRequiredService<TService3>(serviceProvider),
|
|
||||||
GetRequiredService<TService4>(serviceProvider));
|
|
||||||
});
|
|
||||||
}
|
|
||||||
|
|
||||||
private static TService GetRequiredService<TService>(IServiceProvider serviceProvider)
|
|
||||||
{
|
|
||||||
var service = (TService)serviceProvider.GetService(typeof(TService));
|
|
||||||
|
|
||||||
if (service == null)
|
|
||||||
{
|
|
||||||
throw new Exception(string.Format("TODO: No service for type '{0}' has been registered.", typeof(TService)));
|
|
||||||
}
|
|
||||||
|
|
||||||
return service;
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
@ -1,138 +0,0 @@
|
||||||
// Copyright (c) .NET Foundation. All rights reserved.
|
|
||||||
// Licensed under the Apache License, Version 2.0. See License.txt in the project root for license information.
|
|
||||||
|
|
||||||
using System;
|
|
||||||
using System.Collections.Generic;
|
|
||||||
using System.Threading.Tasks;
|
|
||||||
using Microsoft.AspNet.Builder;
|
|
||||||
using Microsoft.Framework.DependencyInjection;
|
|
||||||
using Xunit;
|
|
||||||
|
|
||||||
namespace Microsoft.AspNet.Http.Extensions.Tests
|
|
||||||
{
|
|
||||||
public class UseWithServicesTests
|
|
||||||
{
|
|
||||||
[Fact]
|
|
||||||
public async Task CallingUseThatAlsoTakesServices()
|
|
||||||
{
|
|
||||||
var builder = new ApplicationBuilder(new ServiceCollection()
|
|
||||||
.AddScoped<ITestService, TestService>()
|
|
||||||
.BuildServiceProvider());
|
|
||||||
|
|
||||||
ITestService theService = null;
|
|
||||||
builder.Use<ITestService>(async (ctx, next, testService) =>
|
|
||||||
{
|
|
||||||
theService = testService;
|
|
||||||
await next();
|
|
||||||
});
|
|
||||||
|
|
||||||
var app = builder.Build();
|
|
||||||
await app(new DefaultHttpContext());
|
|
||||||
|
|
||||||
Assert.IsType<TestService>(theService);
|
|
||||||
}
|
|
||||||
|
|
||||||
[Fact]
|
|
||||||
public async Task ServicesArePerRequest()
|
|
||||||
{
|
|
||||||
var services = new ServiceCollection()
|
|
||||||
.AddScoped<ITestService, TestService>()
|
|
||||||
.BuildServiceProvider();
|
|
||||||
var builder = new ApplicationBuilder(services);
|
|
||||||
|
|
||||||
builder.Use(async (ctx, next) =>
|
|
||||||
{
|
|
||||||
var serviceScopeFactory = services.GetRequiredService<IServiceScopeFactory>();
|
|
||||||
using (var serviceScope = serviceScopeFactory.CreateScope())
|
|
||||||
{
|
|
||||||
var priorApplicationServices = ctx.ApplicationServices;
|
|
||||||
var priorRequestServices = ctx.ApplicationServices;
|
|
||||||
ctx.ApplicationServices = services;
|
|
||||||
ctx.RequestServices = serviceScope.ServiceProvider;
|
|
||||||
try
|
|
||||||
{
|
|
||||||
await next();
|
|
||||||
}
|
|
||||||
finally
|
|
||||||
{
|
|
||||||
ctx.ApplicationServices = priorApplicationServices;
|
|
||||||
ctx.RequestServices = priorRequestServices;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
});
|
|
||||||
|
|
||||||
var testServicesA = new List<ITestService>();
|
|
||||||
builder.Use(async (HttpContext ctx, Func<Task> next, ITestService testService) =>
|
|
||||||
{
|
|
||||||
testServicesA.Add(testService);
|
|
||||||
await next();
|
|
||||||
});
|
|
||||||
|
|
||||||
var testServicesB = new List<ITestService>();
|
|
||||||
builder.Use<ITestService>(async (ctx, next, testService) =>
|
|
||||||
{
|
|
||||||
testServicesB.Add(testService);
|
|
||||||
await next();
|
|
||||||
});
|
|
||||||
|
|
||||||
var app = builder.Build();
|
|
||||||
await app(new DefaultHttpContext());
|
|
||||||
await app(new DefaultHttpContext());
|
|
||||||
|
|
||||||
Assert.Equal(2, testServicesA.Count);
|
|
||||||
Assert.IsType<TestService>(testServicesA[0]);
|
|
||||||
Assert.IsType<TestService>(testServicesA[1]);
|
|
||||||
|
|
||||||
Assert.Equal(2, testServicesB.Count);
|
|
||||||
Assert.IsType<TestService>(testServicesB[0]);
|
|
||||||
Assert.IsType<TestService>(testServicesB[1]);
|
|
||||||
|
|
||||||
Assert.Same(testServicesA[0], testServicesB[0]);
|
|
||||||
Assert.Same(testServicesA[1], testServicesB[1]);
|
|
||||||
|
|
||||||
Assert.NotSame(testServicesA[0], testServicesA[1]);
|
|
||||||
Assert.NotSame(testServicesB[0], testServicesB[1]);
|
|
||||||
}
|
|
||||||
|
|
||||||
[Fact]
|
|
||||||
public async Task InvokeMethodWillAllowPerRequestServices()
|
|
||||||
{
|
|
||||||
var services = new ServiceCollection()
|
|
||||||
.AddScoped<ITestService, TestService>()
|
|
||||||
.BuildServiceProvider();
|
|
||||||
var builder = new ApplicationBuilder(services);
|
|
||||||
builder.UseMiddleware<TestMiddleware>();
|
|
||||||
var app = builder.Build();
|
|
||||||
|
|
||||||
var ctx1 = new DefaultHttpContext();
|
|
||||||
await app(ctx1);
|
|
||||||
|
|
||||||
var testService = ctx1.Items[typeof(ITestService)];
|
|
||||||
Assert.IsType<TestService>(testService);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
public interface ITestService
|
|
||||||
{
|
|
||||||
}
|
|
||||||
|
|
||||||
public class TestService : ITestService
|
|
||||||
{
|
|
||||||
}
|
|
||||||
|
|
||||||
public class TestMiddleware
|
|
||||||
{
|
|
||||||
RequestDelegate _next;
|
|
||||||
|
|
||||||
public TestMiddleware(RequestDelegate next)
|
|
||||||
{
|
|
||||||
_next = next;
|
|
||||||
}
|
|
||||||
|
|
||||||
public Task Invoke(HttpContext context, ITestService testService)
|
|
||||||
{
|
|
||||||
context.Items[typeof(ITestService)] = testService;
|
|
||||||
return Task.FromResult(0);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
Loading…
Reference in New Issue