|
1 | 1 | using System.Collections.Concurrent; |
2 | | -using System.Collections.Generic; |
3 | 2 | using System.IO; |
4 | | -using System.Linq; |
5 | | -using System.Reflection; |
6 | 3 | using System.Threading.Tasks; |
7 | 4 | using Microsoft.AspNetCore.Http; |
| 5 | +using Microsoft.AspNetCore.Http.Features; |
8 | 6 | using Microsoft.Extensions.Caching.Memory; |
9 | 7 | using Microsoft.Extensions.Logging; |
10 | 8 | using Microsoft.Extensions.Options; |
@@ -38,6 +36,7 @@ public async Task AssetMiddleware_NoCache() |
38 | 36 | .Returns(response.Object); |
39 | 37 |
|
40 | 38 | context.Setup(c => c.Request.Path).Returns("/file.css"); |
| 39 | + context.Setup(c => c.Features.Get<IHttpsCompressionFeature>()).Returns((IHttpsCompressionFeature) null); |
41 | 40 |
|
42 | 41 | response.SetupGet(c => c.Headers) |
43 | 42 | .Returns(new HeaderDictionary()); |
@@ -131,6 +130,7 @@ public async Task AssetMiddleware_Cache() |
131 | 130 | .Returns(response.Object); |
132 | 131 |
|
133 | 132 | context.Setup(c => c.Request.Path).Returns("/file.css"); |
| 133 | + context.Setup(c => c.Features.Get<IHttpsCompressionFeature>()).Returns((IHttpsCompressionFeature) null); |
134 | 134 |
|
135 | 135 | var next = new Mock<RequestDelegate>(); |
136 | 136 | var env = new HostingEnvironment(); |
@@ -247,5 +247,66 @@ public async Task AssetMiddleware_NoAssetMatch() |
247 | 247 | next.Verify(n => n(context.Object), Times.Once); |
248 | 248 |
|
249 | 249 | } |
| 250 | + |
| 251 | + [Fact2] |
| 252 | + public async Task AssetMiddleware_Compression() |
| 253 | + { |
| 254 | + var cssContent = "*{color:red}".AsByteArray(); |
| 255 | + |
| 256 | + var pipeline = new AssetPipeline(); |
| 257 | + var options = new WebOptimizerOptions() { HttpsCompression = HttpsCompressionMode.Compress }; |
| 258 | + var asset = new Mock<IAsset>().SetupAllProperties(); |
| 259 | + asset.SetupGet(a => a.ContentType).Returns("text/css"); |
| 260 | + asset.SetupGet(a => a.Route).Returns("/file.css"); |
| 261 | + asset.Setup(a => a.ExecuteAsync(It.IsAny<HttpContext>(), options)) |
| 262 | + .Returns(Task.FromResult(cssContent)); |
| 263 | + |
| 264 | + StringValues values; |
| 265 | + var response = new Mock<HttpResponse>().SetupAllProperties(); |
| 266 | + var context = new Mock<HttpContext>().SetupAllProperties(); |
| 267 | + context.Setup(s => s.Request.Headers.TryGetValue("Accept-Encoding", out values)) |
| 268 | + .Returns(false); |
| 269 | + context.Setup(c => c.Response) |
| 270 | + .Returns(response.Object); |
| 271 | + |
| 272 | + context.Setup(c => c.Request.Path).Returns("/file.css"); |
| 273 | + |
| 274 | + var compressionFeature = new HttpsCompressionFeature(); |
| 275 | + context.Setup(c => c.Features.Get<IHttpsCompressionFeature>()).Returns(compressionFeature); |
| 276 | + |
| 277 | + var next = new Mock<RequestDelegate>(); |
| 278 | + var cache = new Mock<IMemoryCache>(); |
| 279 | + var mcr = new AssetResponse(cssContent, null); |
| 280 | + |
| 281 | + object bytes = mcr; |
| 282 | + cache.Setup(c => c.TryGetValue(It.IsAny<string>(), out bytes)) |
| 283 | + .Returns(true); |
| 284 | + |
| 285 | + pipeline._assets = new ConcurrentDictionary<string, IAsset>(); |
| 286 | + pipeline._assets.TryAdd(asset.Object.Route, asset.Object); |
| 287 | + |
| 288 | + var amo = new Mock<IOptionsSnapshot<WebOptimizerOptions>>(); |
| 289 | + amo.SetupGet(a => a.Value).Returns(options); |
| 290 | + |
| 291 | + var logger = new Mock<ILogger<AssetMiddleware>>(); |
| 292 | + var builder = new Mock<IAssetBuilder>(); |
| 293 | + builder.Setup(b => b.BuildAsync(It.IsAny<IAsset>(), context.Object, options)).Returns(Task.FromResult<IAssetResponse>(mcr)); |
| 294 | + var middleware = new AssetMiddleware(next.Object, pipeline, logger.Object, builder.Object); |
| 295 | + var stream = new MemoryStream(); |
| 296 | + |
| 297 | + response.Setup(r => r.Body).Returns(stream); |
| 298 | + await middleware.InvokeAsync(context.Object, amo.Object); |
| 299 | + |
| 300 | + Assert.Equal("text/css", context.Object.Response.ContentType); |
| 301 | + Assert.Equal(cssContent, await stream.AsBytesAsync()); |
| 302 | + Assert.Equal(0, response.Object.StatusCode); |
| 303 | + |
| 304 | + Assert.Equal(compressionFeature.Mode, HttpsCompressionMode.Compress); |
| 305 | + } |
| 306 | + |
| 307 | + private class HttpsCompressionFeature : IHttpsCompressionFeature |
| 308 | + { |
| 309 | + public HttpsCompressionMode Mode { get; set; } |
| 310 | + } |
250 | 311 | } |
251 | 312 | } |
0 commit comments