mirror of
				https://github.com/nsnail/Ocelot.git
				synced 2025-10-21 04:32:27 +08:00 
			
		
		
		
	
		
			
				
	
	
		
			728 lines
		
	
	
		
			30 KiB
		
	
	
	
		
			C#
		
	
	
	
	
	
			
		
		
	
	
			728 lines
		
	
	
		
			30 KiB
		
	
	
	
		
			C#
		
	
	
	
	
	
| using System;
 | |
| using System.Collections.Generic;
 | |
| using System.IO;
 | |
| using System.Net;
 | |
| using System.Net.Http;
 | |
| using System.Net.Http.Headers;
 | |
| using System.Security.Claims;
 | |
| using CacheManager.Core;
 | |
| using IdentityServer4.AccessTokenValidation;
 | |
| using IdentityServer4.Models;
 | |
| using IdentityServer4.Test;
 | |
| using Microsoft.AspNetCore.Builder;
 | |
| using Microsoft.AspNetCore.Hosting;
 | |
| using Microsoft.Extensions.Configuration;
 | |
| using Microsoft.Extensions.DependencyInjection;
 | |
| using Microsoft.Extensions.Logging;
 | |
| using Newtonsoft.Json;
 | |
| using Ocelot.Cache;
 | |
| using Ocelot.Configuration.File;
 | |
| using Ocelot.DependencyInjection;
 | |
| using Ocelot.Middleware;
 | |
| using Shouldly;
 | |
| using TestStack.BDDfy;
 | |
| using Xunit;
 | |
| 
 | |
| [assembly: CollectionBehavior(DisableTestParallelization = true)]
 | |
| namespace Ocelot.IntegrationTests
 | |
| {
 | |
|     public class AdministrationTests : IDisposable
 | |
|     {
 | |
|         private HttpClient _httpClient;
 | |
|         private readonly HttpClient _httpClientTwo;
 | |
|         private HttpResponseMessage _response;
 | |
|         private IWebHost _builder;
 | |
|         private IWebHostBuilder _webHostBuilder;
 | |
|         private string _ocelotBaseUrl;
 | |
|         private BearerToken _token;
 | |
|         private IWebHostBuilder _webHostBuilderTwo;
 | |
|         private IWebHost _builderTwo;
 | |
|         private IWebHost _identityServerBuilder;
 | |
| 
 | |
|         public AdministrationTests()
 | |
|         {
 | |
|             _httpClient = new HttpClient();
 | |
|             _httpClientTwo = new HttpClient();
 | |
|             _ocelotBaseUrl = "http://localhost:5000";
 | |
|             _httpClient.BaseAddress = new Uri(_ocelotBaseUrl);
 | |
|         }
 | |
| 
 | |
|         [Fact]
 | |
|         public void should_return_response_401_with_call_re_routes_controller()
 | |
|         {
 | |
|             var configuration = new FileConfiguration();
 | |
| 
 | |
|             this.Given(x => GivenThereIsAConfiguration(configuration))
 | |
|                 .And(x => GivenOcelotIsRunning())
 | |
|                 .When(x => WhenIGetUrlOnTheApiGateway("/administration/configuration"))
 | |
|                 .Then(x => ThenTheStatusCodeShouldBe(HttpStatusCode.Unauthorized))
 | |
|                 .BDDfy();
 | |
|         }
 | |
| 
 | |
|          [Fact]
 | |
|          public void should_return_response_200_with_call_re_routes_controller()
 | |
|          {
 | |
|             var configuration = new FileConfiguration();
 | |
| 
 | |
|              this.Given(x => GivenThereIsAConfiguration(configuration))
 | |
|                  .And(x => GivenOcelotIsRunning())
 | |
|                  .And(x => GivenIHaveAnOcelotToken("/administration"))
 | |
|                  .And(x => GivenIHaveAddedATokenToMyRequest())
 | |
|                  .When(x => WhenIGetUrlOnTheApiGateway("/administration/configuration"))
 | |
|                  .Then(x => ThenTheStatusCodeShouldBe(HttpStatusCode.OK))
 | |
|                  .BDDfy();
 | |
|          }
 | |
| 
 | |
|         [Fact]
 | |
|         public void should_return_response_200_with_call_re_routes_controller_using_base_url_added_in_file_config()
 | |
|         {
 | |
|             _httpClient = new HttpClient();
 | |
|             _ocelotBaseUrl = "http://localhost:5011";
 | |
|             _httpClient.BaseAddress = new Uri(_ocelotBaseUrl);
 | |
| 
 | |
|             var configuration = new FileConfiguration
 | |
|             {
 | |
|                 GlobalConfiguration = new FileGlobalConfiguration
 | |
|                 {
 | |
|                     BaseUrl = _ocelotBaseUrl
 | |
|                 }
 | |
|             };
 | |
| 
 | |
|             this.Given(x => GivenThereIsAConfiguration(configuration))
 | |
|                 .And(x => GivenOcelotIsRunningWithNoWebHostBuilder(_ocelotBaseUrl))
 | |
|                 .And(x => GivenIHaveAnOcelotToken("/administration"))
 | |
|                 .And(x => GivenIHaveAddedATokenToMyRequest())
 | |
|                 .When(x => WhenIGetUrlOnTheApiGateway("/administration/configuration"))
 | |
|                 .Then(x => ThenTheStatusCodeShouldBe(HttpStatusCode.OK))
 | |
|                 .BDDfy();
 | |
|         }
 | |
| 
 | |
|         [Fact]
 | |
|         public void should_be_able_to_use_token_from_ocelot_a_on_ocelot_b()
 | |
|         {
 | |
|             var configuration = new FileConfiguration();
 | |
| 
 | |
|             this.Given(x => GivenThereIsAConfiguration(configuration))
 | |
|                 .And(x => GivenIdentityServerSigningEnvironmentalVariablesAreSet())
 | |
|                 .And(x => GivenOcelotIsRunning())
 | |
|                 .And(x => GivenIHaveAnOcelotToken("/administration"))
 | |
|                 .And(x => GivenAnotherOcelotIsRunning("http://localhost:5007"))
 | |
|                 .When(x => WhenIGetUrlOnTheSecondOcelot("/administration/configuration"))
 | |
|                 .Then(x => ThenTheStatusCodeShouldBe(HttpStatusCode.OK))
 | |
|                 .BDDfy();
 | |
|         }
 | |
| 
 | |
|         [Fact]
 | |
|         public void should_return_file_configuration()
 | |
|         {
 | |
|             var configuration = new FileConfiguration
 | |
|             {
 | |
|                 GlobalConfiguration = new FileGlobalConfiguration
 | |
|                 {
 | |
|                     RequestIdKey = "RequestId",
 | |
|                     ServiceDiscoveryProvider = new FileServiceDiscoveryProvider
 | |
|                     {
 | |
|                         Host = "127.0.0.1",
 | |
|                     }
 | |
|                 },
 | |
|                 ReRoutes = new List<FileReRoute>()
 | |
|                 {
 | |
|                     new FileReRoute()
 | |
|                     {
 | |
|                         DownstreamHostAndPorts = new List<FileHostAndPort>
 | |
|                         {
 | |
|                             new FileHostAndPort
 | |
|                             {
 | |
|                                 Host = "localhost",
 | |
|                                 Port = 80,
 | |
|                             }
 | |
|                         },
 | |
|                         DownstreamScheme = "https",
 | |
|                         DownstreamPathTemplate = "/",
 | |
|                         UpstreamHttpMethod = new List<string> { "get" },
 | |
|                         UpstreamPathTemplate = "/",
 | |
|                         FileCacheOptions = new FileCacheOptions
 | |
|                         {
 | |
|                             TtlSeconds = 10,
 | |
|                             Region = "Geoff"
 | |
|                         }
 | |
|                     },
 | |
|                     new FileReRoute()
 | |
|                     {
 | |
|                         DownstreamHostAndPorts = new List<FileHostAndPort>
 | |
|                         {
 | |
|                             new FileHostAndPort
 | |
|                             {
 | |
|                                 Host = "localhost",
 | |
|                                 Port = 80,
 | |
|                             }
 | |
|                         },
 | |
|                         DownstreamScheme = "https",
 | |
|                         DownstreamPathTemplate = "/",
 | |
|                         UpstreamHttpMethod = new List<string> { "get" },
 | |
|                         UpstreamPathTemplate = "/test",
 | |
|                         FileCacheOptions = new FileCacheOptions
 | |
|                         {
 | |
|                             TtlSeconds = 10,
 | |
|                             Region = "Dave"
 | |
|                         }
 | |
|                     }
 | |
|                 }
 | |
|             };
 | |
| 
 | |
|             this.Given(x => GivenThereIsAConfiguration(configuration))
 | |
|                 .And(x => GivenOcelotIsRunning())
 | |
|                 .And(x => GivenIHaveAnOcelotToken("/administration"))
 | |
|                 .And(x => GivenIHaveAddedATokenToMyRequest())
 | |
|                 .When(x => WhenIGetUrlOnTheApiGateway("/administration/configuration"))
 | |
|                 .Then(x => ThenTheStatusCodeShouldBe(HttpStatusCode.OK))
 | |
|                 .And(x => ThenTheResponseShouldBe(configuration))
 | |
|                 .BDDfy();
 | |
|         }
 | |
| 
 | |
|         [Fact]
 | |
|         public void should_get_file_configuration_edit_and_post_updated_version()
 | |
|         {
 | |
|             var initialConfiguration = new FileConfiguration
 | |
|             {
 | |
|                 GlobalConfiguration = new FileGlobalConfiguration
 | |
|                 {
 | |
|                 },
 | |
|                 ReRoutes = new List<FileReRoute>()
 | |
|                 {
 | |
|                     new FileReRoute()
 | |
|                     {
 | |
|                         DownstreamHostAndPorts = new List<FileHostAndPort>
 | |
|                         {
 | |
|                             new FileHostAndPort
 | |
|                             {
 | |
|                                 Host = "localhost",
 | |
|                                 Port = 80,
 | |
|                             }
 | |
|                         },
 | |
|                         DownstreamScheme = "https",
 | |
|                         DownstreamPathTemplate = "/",
 | |
|                         UpstreamHttpMethod = new List<string> { "get" },
 | |
|                         UpstreamPathTemplate = "/"
 | |
|                     },
 | |
|                     new FileReRoute()
 | |
|                     {
 | |
|                         DownstreamHostAndPorts = new List<FileHostAndPort>
 | |
|                         {
 | |
|                             new FileHostAndPort
 | |
|                             {
 | |
|                                 Host = "localhost",
 | |
|                                 Port = 80,
 | |
|                             }
 | |
|                         },
 | |
|                         DownstreamScheme = "https",
 | |
|                         DownstreamPathTemplate = "/",
 | |
|                         UpstreamHttpMethod = new List<string> { "get" },
 | |
|                         UpstreamPathTemplate = "/test"
 | |
|                     }
 | |
|                 }
 | |
|             };
 | |
| 
 | |
|              var updatedConfiguration = new FileConfiguration
 | |
|             {
 | |
|                 GlobalConfiguration = new FileGlobalConfiguration
 | |
|                 {
 | |
|                 },
 | |
|                 ReRoutes = new List<FileReRoute>()
 | |
|                 {
 | |
|                     new FileReRoute()
 | |
|                     {
 | |
|                         DownstreamHostAndPorts = new List<FileHostAndPort>
 | |
|                         {
 | |
|                             new FileHostAndPort
 | |
|                             {
 | |
|                                 Host = "localhost",
 | |
|                                 Port = 80,
 | |
|                             }
 | |
|                         },
 | |
|                         DownstreamScheme = "http",
 | |
|                         DownstreamPathTemplate = "/geoffrey",
 | |
|                         UpstreamHttpMethod = new List<string> { "get" },
 | |
|                         UpstreamPathTemplate = "/"
 | |
|                     },
 | |
|                     new FileReRoute()
 | |
|                     {
 | |
|                         DownstreamHostAndPorts = new List<FileHostAndPort>
 | |
|                         {
 | |
|                             new FileHostAndPort
 | |
|                             {
 | |
|                                 Host = "123.123.123",
 | |
|                                 Port = 443,
 | |
|                             }
 | |
|                         },
 | |
|                         DownstreamScheme = "https",
 | |
|                         DownstreamPathTemplate = "/blooper/{productId}",
 | |
|                         UpstreamHttpMethod = new List<string> { "post" },
 | |
|                         UpstreamPathTemplate = "/test"
 | |
|                     }
 | |
|                 }
 | |
|             };
 | |
| 
 | |
|             this.Given(x => GivenThereIsAConfiguration(initialConfiguration))
 | |
|                 .And(x => GivenOcelotIsRunning())
 | |
|                 .And(x => GivenIHaveAnOcelotToken("/administration"))
 | |
|                 .And(x => GivenIHaveAddedATokenToMyRequest())
 | |
|                 .When(x => WhenIGetUrlOnTheApiGateway("/administration/configuration"))
 | |
|                 .When(x => WhenIPostOnTheApiGateway("/administration/configuration", updatedConfiguration))
 | |
|                 .Then(x => ThenTheStatusCodeShouldBe(HttpStatusCode.OK))
 | |
|                 .And(x => ThenTheResponseShouldBe(updatedConfiguration))
 | |
|                 .When(x => WhenIGetUrlOnTheApiGateway("/administration/configuration"))
 | |
|                 .And(x => ThenTheResponseShouldBe(updatedConfiguration))
 | |
|                 .BDDfy();
 | |
|         }
 | |
| 
 | |
|         [Fact]
 | |
|         public void should_clear_region()
 | |
|         {
 | |
|             var initialConfiguration = new FileConfiguration
 | |
|             {
 | |
|                 GlobalConfiguration = new FileGlobalConfiguration
 | |
|                 {
 | |
|                 },
 | |
|                 ReRoutes = new List<FileReRoute>()
 | |
|                 {
 | |
|                     new FileReRoute()
 | |
|                     {
 | |
|                         DownstreamHostAndPorts = new List<FileHostAndPort>
 | |
|                         {
 | |
|                             new FileHostAndPort
 | |
|                             {
 | |
|                                 Host = "localhost",
 | |
|                                 Port = 80,
 | |
|                             }
 | |
|                         },
 | |
|                         DownstreamScheme = "https",
 | |
|                         DownstreamPathTemplate = "/",
 | |
|                         UpstreamHttpMethod = new List<string> { "get" },
 | |
|                         UpstreamPathTemplate = "/",
 | |
|                         FileCacheOptions = new FileCacheOptions
 | |
|                         {
 | |
|                             TtlSeconds = 10
 | |
|                         }
 | |
|                     },
 | |
|                     new FileReRoute()
 | |
|                     {
 | |
|                         DownstreamHostAndPorts = new List<FileHostAndPort>
 | |
|                         {
 | |
|                             new FileHostAndPort
 | |
|                             {
 | |
|                                 Host = "localhost",
 | |
|                                 Port = 80,
 | |
|                             }
 | |
|                         },
 | |
|                         DownstreamScheme = "https",
 | |
|                         DownstreamPathTemplate = "/",
 | |
|                         UpstreamHttpMethod = new List<string> { "get" },
 | |
|                         UpstreamPathTemplate = "/test",
 | |
|                         FileCacheOptions = new FileCacheOptions
 | |
|                         {
 | |
|                             TtlSeconds = 10
 | |
|                         }
 | |
|                     }
 | |
|                 }
 | |
|             };
 | |
| 
 | |
|             var regionToClear = "gettest";
 | |
| 
 | |
|             this.Given(x => GivenThereIsAConfiguration(initialConfiguration))
 | |
|                 .And(x => GivenOcelotIsRunning())
 | |
|                 .And(x => GivenIHaveAnOcelotToken("/administration"))
 | |
|                 .And(x => GivenIHaveAddedATokenToMyRequest())
 | |
|                 .When(x => WhenIDeleteOnTheApiGateway($"/administration/outputcache/{regionToClear}"))
 | |
|                 .Then(x => ThenTheStatusCodeShouldBe(HttpStatusCode.NoContent))
 | |
|                 .BDDfy();
 | |
|         }
 | |
| 
 | |
|          [Fact]
 | |
|          public void should_return_response_200_with_call_re_routes_controller_when_using_own_identity_server_to_secure_admin_area()
 | |
|          {
 | |
|             var configuration = new FileConfiguration();
 | |
| 
 | |
|             var identityServerRootUrl = "http://localhost:5123";
 | |
| 
 | |
|             Action<IdentityServerAuthenticationOptions> options = o => {
 | |
|                 o.Authority = identityServerRootUrl;
 | |
|                 o.ApiName = "api";
 | |
|                 o.RequireHttpsMetadata = false;
 | |
|                 o.SupportedTokens = SupportedTokens.Both;
 | |
|                 o.ApiSecret = "secret";
 | |
|             };
 | |
| 
 | |
|              this.Given(x => GivenThereIsAConfiguration(configuration))
 | |
|                  .And(x => GivenThereIsAnIdentityServerOn(identityServerRootUrl, "api"))
 | |
|                  .And(x => GivenOcelotIsRunningWithIdentityServerSettings(options))
 | |
|                  .And(x => GivenIHaveAToken(identityServerRootUrl))
 | |
|                  .And(x => GivenIHaveAddedATokenToMyRequest())
 | |
|                  .When(x => WhenIGetUrlOnTheApiGateway("/administration/configuration"))
 | |
|                  .Then(x => ThenTheStatusCodeShouldBe(HttpStatusCode.OK))
 | |
|                  .BDDfy();
 | |
|          }
 | |
| 
 | |
|         private void GivenIHaveAToken(string url)
 | |
|         {
 | |
|             var formData = new List<KeyValuePair<string, string>>
 | |
|             {
 | |
|                 new KeyValuePair<string, string>("client_id", "api"),
 | |
|                 new KeyValuePair<string, string>("client_secret", "secret"),
 | |
|                 new KeyValuePair<string, string>("scope", "api"),
 | |
|                 new KeyValuePair<string, string>("username", "test"),
 | |
|                 new KeyValuePair<string, string>("password", "test"),
 | |
|                 new KeyValuePair<string, string>("grant_type", "password")
 | |
|             };
 | |
|             var content = new FormUrlEncodedContent(formData);
 | |
| 
 | |
|             using (var httpClient = new HttpClient())
 | |
|             {
 | |
|                 var response = httpClient.PostAsync($"{url}/connect/token", content).Result;
 | |
|                 var responseContent = response.Content.ReadAsStringAsync().Result;
 | |
|                 response.EnsureSuccessStatusCode();
 | |
|                 _token = JsonConvert.DeserializeObject<BearerToken>(responseContent);
 | |
|             }
 | |
|         }
 | |
| 
 | |
|           private void GivenThereIsAnIdentityServerOn(string url, string apiName)
 | |
|         {
 | |
|             _identityServerBuilder = new WebHostBuilder()
 | |
|                 .UseUrls(url)
 | |
|                 .UseKestrel()
 | |
|                 .UseContentRoot(Directory.GetCurrentDirectory())
 | |
|                 .ConfigureServices(services =>
 | |
|                 {
 | |
|                     services.AddLogging();
 | |
|                     services.AddIdentityServer()
 | |
|                     .AddDeveloperSigningCredential()
 | |
|                         .AddInMemoryApiResources(new List<ApiResource>
 | |
|                         {
 | |
|                             new ApiResource
 | |
|                             {
 | |
|                                 Name = apiName,
 | |
|                                 Description = apiName,
 | |
|                                 Enabled = true,
 | |
|                                 DisplayName = apiName,
 | |
|                                 Scopes = new List<Scope>()
 | |
|                                 {
 | |
|                                     new Scope(apiName)
 | |
|                                 }
 | |
|                             }
 | |
|                         })
 | |
|                         .AddInMemoryClients(new List<Client>
 | |
|                         {
 | |
|                             new Client
 | |
|                             {
 | |
|                                 ClientId = apiName,
 | |
|                                 AllowedGrantTypes = GrantTypes.ResourceOwnerPassword,
 | |
|                                 ClientSecrets = new List<Secret> {new Secret("secret".Sha256())},
 | |
|                                 AllowedScopes = new List<string> { apiName },
 | |
|                                 AccessTokenType = AccessTokenType.Jwt,
 | |
|                                 Enabled = true
 | |
|                             }
 | |
|                         })
 | |
|                         .AddTestUsers(new List<TestUser>
 | |
|                         {
 | |
|                             new TestUser
 | |
|                             {
 | |
|                                 Username = "test",
 | |
|                                 Password = "test",
 | |
|                                 SubjectId = "1231231"
 | |
|                             }
 | |
|                         });
 | |
|                 })
 | |
|                 .Configure(app =>
 | |
|                 {
 | |
|                     app.UseIdentityServer();
 | |
|                 })
 | |
|                 .Build();
 | |
| 
 | |
|                 _identityServerBuilder.Start();
 | |
| 
 | |
|                 using (var httpClient = new HttpClient())
 | |
|                 {
 | |
|                     var response = httpClient.GetAsync($"{url}/.well-known/openid-configuration").Result;
 | |
|                     response.EnsureSuccessStatusCode();
 | |
|                 }        
 | |
|             }
 | |
| 
 | |
|         private void GivenAnotherOcelotIsRunning(string baseUrl)
 | |
|         {
 | |
|             _httpClientTwo.BaseAddress = new Uri(baseUrl);
 | |
| 
 | |
|             _webHostBuilderTwo = new WebHostBuilder()
 | |
|                .UseUrls(baseUrl)
 | |
|                .UseKestrel()
 | |
|                .UseContentRoot(Directory.GetCurrentDirectory())
 | |
|                .ConfigureAppConfiguration((hostingContext, config) =>
 | |
|                {
 | |
|                    config.SetBasePath(hostingContext.HostingEnvironment.ContentRootPath);
 | |
|                    var env = hostingContext.HostingEnvironment;
 | |
|                    config.AddJsonFile("appsettings.json", optional: true, reloadOnChange: true)
 | |
|                        .AddJsonFile($"appsettings.{env.EnvironmentName}.json", optional: true, reloadOnChange: true);
 | |
|                    config.AddJsonFile("configuration.json");
 | |
|                    config.AddEnvironmentVariables();
 | |
|                })
 | |
|                .ConfigureServices(x =>
 | |
|                {
 | |
|                    Action<ConfigurationBuilderCachePart> settings = (s) =>
 | |
|                    {
 | |
|                        s.WithMicrosoftLogging(log =>
 | |
|                        {
 | |
|                            log.AddConsole(LogLevel.Debug);
 | |
|                        })
 | |
|                            .WithDictionaryHandle();
 | |
|                    };
 | |
| 
 | |
|                    x.AddOcelot()
 | |
|                        .AddCacheManager(settings)
 | |
|                        .AddAdministration("/administration", "secret");
 | |
|                })
 | |
|                .Configure(app =>
 | |
|                {
 | |
|                    app.UseOcelot().Wait();
 | |
|                });
 | |
| 
 | |
|             _builderTwo = _webHostBuilderTwo.Build();
 | |
| 
 | |
|             _builderTwo.Start();
 | |
|         }
 | |
| 
 | |
|         private void GivenIdentityServerSigningEnvironmentalVariablesAreSet()
 | |
|         {
 | |
|             Environment.SetEnvironmentVariable("OCELOT_CERTIFICATE", "idsrv3test.pfx");
 | |
|             Environment.SetEnvironmentVariable("OCELOT_CERTIFICATE_PASSWORD", "idsrv3test");
 | |
|         }
 | |
| 
 | |
|         private void WhenIGetUrlOnTheSecondOcelot(string url)
 | |
|         {
 | |
|             _httpClientTwo.DefaultRequestHeaders.Authorization = new AuthenticationHeaderValue("Bearer", _token.AccessToken);
 | |
|             _response = _httpClientTwo.GetAsync(url).Result;
 | |
|         }
 | |
| 
 | |
|         private void WhenIPostOnTheApiGateway(string url, FileConfiguration updatedConfiguration)
 | |
|         {
 | |
|             var json = JsonConvert.SerializeObject(updatedConfiguration);
 | |
|             var content = new StringContent(json);
 | |
|             content.Headers.ContentType = new MediaTypeHeaderValue("application/json");
 | |
|             _response = _httpClient.PostAsync(url, content).Result;
 | |
|         }
 | |
| 
 | |
|         private void ThenTheResponseShouldBe(List<string> expected)
 | |
|         {
 | |
|             var content = _response.Content.ReadAsStringAsync().Result;
 | |
|             var result = JsonConvert.DeserializeObject<Regions>(content);
 | |
|             result.Value.ShouldBe(expected);
 | |
|         }
 | |
| 
 | |
|         private void ThenTheResponseShouldBe(FileConfiguration expecteds)
 | |
|         {
 | |
|             var response = JsonConvert.DeserializeObject<FileConfiguration>(_response.Content.ReadAsStringAsync().Result);
 | |
| 
 | |
|             response.GlobalConfiguration.RequestIdKey.ShouldBe(expecteds.GlobalConfiguration.RequestIdKey);
 | |
|             response.GlobalConfiguration.ServiceDiscoveryProvider.Host.ShouldBe(expecteds.GlobalConfiguration.ServiceDiscoveryProvider.Host);
 | |
|             response.GlobalConfiguration.ServiceDiscoveryProvider.Port.ShouldBe(expecteds.GlobalConfiguration.ServiceDiscoveryProvider.Port);
 | |
| 
 | |
|             for (var i = 0; i < response.ReRoutes.Count; i++)
 | |
|             {
 | |
|                 for (var j = 0; j < response.ReRoutes[i].DownstreamHostAndPorts.Count; j++)
 | |
|                 {
 | |
|                     var result = response.ReRoutes[i].DownstreamHostAndPorts[j];
 | |
|                     var expected = expecteds.ReRoutes[i].DownstreamHostAndPorts[j];
 | |
|                     result.Host.ShouldBe(expected.Host);
 | |
|                     result.Port.ShouldBe(expected.Port);
 | |
|                 }
 | |
| 
 | |
|                 response.ReRoutes[i].DownstreamPathTemplate.ShouldBe(expecteds.ReRoutes[i].DownstreamPathTemplate);
 | |
|                 response.ReRoutes[i].DownstreamScheme.ShouldBe(expecteds.ReRoutes[i].DownstreamScheme);
 | |
|                 response.ReRoutes[i].UpstreamPathTemplate.ShouldBe(expecteds.ReRoutes[i].UpstreamPathTemplate);
 | |
|                 response.ReRoutes[i].UpstreamHttpMethod.ShouldBe(expecteds.ReRoutes[i].UpstreamHttpMethod);
 | |
|             }
 | |
|         }
 | |
| 
 | |
|         private void GivenIHaveAddedATokenToMyRequest()
 | |
|         {
 | |
|             _httpClient.DefaultRequestHeaders.Authorization = new AuthenticationHeaderValue("Bearer", _token.AccessToken);
 | |
|         }
 | |
| 
 | |
|         private void GivenIHaveAnOcelotToken(string adminPath)
 | |
|         {
 | |
|             var tokenUrl = $"{adminPath}/connect/token";
 | |
|             var formData = new List<KeyValuePair<string, string>>
 | |
|             {
 | |
|                 new KeyValuePair<string, string>("client_id", "admin"),
 | |
|                 new KeyValuePair<string, string>("client_secret", "secret"),
 | |
|                 new KeyValuePair<string, string>("scope", "admin"),
 | |
|                 new KeyValuePair<string, string>("grant_type", "client_credentials")
 | |
|             };
 | |
|             var content = new FormUrlEncodedContent(formData);
 | |
| 
 | |
|             var response = _httpClient.PostAsync(tokenUrl, content).Result;
 | |
|             var responseContent = response.Content.ReadAsStringAsync().Result;
 | |
|             response.EnsureSuccessStatusCode();
 | |
|             _token = JsonConvert.DeserializeObject<BearerToken>(responseContent);
 | |
|             var configPath = $"{adminPath}/.well-known/openid-configuration";
 | |
|             response = _httpClient.GetAsync(configPath).Result;
 | |
|             response.EnsureSuccessStatusCode();
 | |
|         }
 | |
| 
 | |
|         private void GivenOcelotIsRunningWithIdentityServerSettings(Action<IdentityServerAuthenticationOptions> configOptions)
 | |
|         {
 | |
|             _webHostBuilder = new WebHostBuilder()
 | |
|                 .UseUrls(_ocelotBaseUrl)
 | |
|                 .UseKestrel()
 | |
|                 .UseContentRoot(Directory.GetCurrentDirectory())
 | |
|                 .ConfigureAppConfiguration((hostingContext, config) =>
 | |
|                 {
 | |
|                     config.SetBasePath(hostingContext.HostingEnvironment.ContentRootPath);
 | |
|                     var env = hostingContext.HostingEnvironment;
 | |
|                     config.AddJsonFile("appsettings.json", optional: true, reloadOnChange: true)
 | |
|                         .AddJsonFile($"appsettings.{env.EnvironmentName}.json", optional: true, reloadOnChange: true);
 | |
|                     config.AddJsonFile("configuration.json");
 | |
|                     config.AddEnvironmentVariables();
 | |
|                 })
 | |
|                 .ConfigureServices(x => {
 | |
|                     x.AddSingleton(_webHostBuilder);
 | |
|                     x.AddOcelot()
 | |
|                     .AddCacheManager(c =>
 | |
|                     {
 | |
|                         c.WithDictionaryHandle();
 | |
|                     })
 | |
|                     .AddAdministration("/administration", configOptions);
 | |
|                     })
 | |
|                     .Configure(app => {
 | |
|                         app.UseOcelot().Wait();
 | |
|                     });
 | |
| 
 | |
|               _builder = _webHostBuilder.Build();
 | |
| 
 | |
|             _builder.Start();
 | |
|         }
 | |
| 
 | |
|         private void GivenOcelotIsRunning()
 | |
|         {
 | |
|             _webHostBuilder = new WebHostBuilder()
 | |
|                 .UseUrls(_ocelotBaseUrl)
 | |
|                 .UseKestrel()
 | |
|                 .UseContentRoot(Directory.GetCurrentDirectory())
 | |
|                 .ConfigureAppConfiguration((hostingContext, config) =>
 | |
|                 {
 | |
|                     config.SetBasePath(hostingContext.HostingEnvironment.ContentRootPath);
 | |
|                     var env = hostingContext.HostingEnvironment;
 | |
|                     config.AddJsonFile("appsettings.json", optional: true, reloadOnChange: true)
 | |
|                         .AddJsonFile($"appsettings.{env.EnvironmentName}.json", optional: true, reloadOnChange: true);
 | |
|                     config.AddJsonFile("configuration.json");
 | |
|                     config.AddEnvironmentVariables();
 | |
|                 })
 | |
|                 .ConfigureServices(x =>
 | |
|                 {
 | |
|                     Action<ConfigurationBuilderCachePart> settings = (s) =>
 | |
|                     {
 | |
|                         s.WithMicrosoftLogging(log =>
 | |
|                             {
 | |
|                                 log.AddConsole(LogLevel.Debug);
 | |
|                             })
 | |
|                             .WithDictionaryHandle();
 | |
|                     };
 | |
| 
 | |
|                     x.AddOcelot()
 | |
|                         .AddCacheManager(settings)
 | |
|                         .AddAdministration("/administration", "secret");
 | |
|                 })
 | |
|                 .Configure(app =>
 | |
|                 {
 | |
|                     app.UseOcelot().Wait();
 | |
|                 });
 | |
| 
 | |
|             _builder = _webHostBuilder.Build();
 | |
| 
 | |
|             _builder.Start();
 | |
|         }
 | |
| 
 | |
|         private void GivenOcelotIsRunningWithNoWebHostBuilder(string baseUrl)
 | |
|         {
 | |
|             _webHostBuilder = new WebHostBuilder()
 | |
|                 .UseUrls(_ocelotBaseUrl)
 | |
|                 .UseKestrel()
 | |
|                 .UseContentRoot(Directory.GetCurrentDirectory())
 | |
|                 .ConfigureAppConfiguration((hostingContext, config) =>
 | |
|                 {
 | |
|                     config.SetBasePath(hostingContext.HostingEnvironment.ContentRootPath);
 | |
|                     var env = hostingContext.HostingEnvironment;
 | |
|                     config.AddJsonFile("appsettings.json", optional: true, reloadOnChange: true)
 | |
|                         .AddJsonFile($"appsettings.{env.EnvironmentName}.json", optional: true, reloadOnChange: true);
 | |
|                     config.AddJsonFile("configuration.json");
 | |
|                     config.AddEnvironmentVariables();
 | |
|                 })
 | |
|                 .ConfigureServices(x => {
 | |
|                     x.AddSingleton(_webHostBuilder);
 | |
|                     x.AddOcelot()
 | |
|                         .AddCacheManager(c =>
 | |
|                         {
 | |
|                             c.WithDictionaryHandle();
 | |
|                         })
 | |
|                         .AddAdministration("/administration", "secret");
 | |
|                 })
 | |
|                 .Configure(app => {
 | |
|                     app.UseOcelot().Wait();
 | |
|                 });
 | |
| 
 | |
|             _builder = _webHostBuilder.Build();
 | |
| 
 | |
|             _builder.Start();
 | |
|         }
 | |
| 
 | |
|         private void GivenThereIsAConfiguration(FileConfiguration fileConfiguration)
 | |
|         {
 | |
|             var configurationPath = $"{Directory.GetCurrentDirectory()}/configuration.json";
 | |
| 
 | |
|             var jsonConfiguration = JsonConvert.SerializeObject(fileConfiguration);
 | |
| 
 | |
|             if (File.Exists(configurationPath))
 | |
|             {
 | |
|                 File.Delete(configurationPath);
 | |
|             }
 | |
| 
 | |
|             File.WriteAllText(configurationPath, jsonConfiguration);
 | |
| 
 | |
|             var text = File.ReadAllText(configurationPath);
 | |
| 
 | |
|             configurationPath = $"{AppContext.BaseDirectory}/configuration.json";
 | |
| 
 | |
|             if (File.Exists(configurationPath))
 | |
|             {
 | |
|                 File.Delete(configurationPath);
 | |
|             }
 | |
| 
 | |
|             File.WriteAllText(configurationPath, jsonConfiguration);
 | |
| 
 | |
|             text = File.ReadAllText(configurationPath);
 | |
|         }
 | |
| 
 | |
|         private void WhenIGetUrlOnTheApiGateway(string url)
 | |
|         {
 | |
|             _response = _httpClient.GetAsync(url).Result;
 | |
|         }
 | |
| 
 | |
|         private void WhenIDeleteOnTheApiGateway(string url)
 | |
|         {
 | |
|             _response = _httpClient.DeleteAsync(url).Result;
 | |
|         }
 | |
| 
 | |
|         private void ThenTheStatusCodeShouldBe(HttpStatusCode expectedHttpStatusCode)
 | |
|         {
 | |
|             _response.StatusCode.ShouldBe(expectedHttpStatusCode);
 | |
|         }
 | |
| 
 | |
|         public void Dispose()
 | |
|         {
 | |
|             Environment.SetEnvironmentVariable("OCELOT_CERTIFICATE", "");
 | |
|             Environment.SetEnvironmentVariable("OCELOT_CERTIFICATE_PASSWORD", "");
 | |
|             _builder?.Dispose();
 | |
|             _httpClient?.Dispose();
 | |
|             _identityServerBuilder?.Dispose();
 | |
|         }
 | |
|     }
 | |
| }
 | 
