Browse Source

Fixed catalog functional tests

rebond/dev
David Fowler 1 year ago
parent
commit
2736eae13e
2 changed files with 28 additions and 28 deletions
  1. +11
    -11
      src/Services/Catalog/Catalog.API/Extensions/WebHostExtensions.cs
  2. +17
    -17
      src/Services/Catalog/Catalog.FunctionalTests/CatalogScenarioBase.cs

+ 11
- 11
src/Services/Catalog/Catalog.API/Extensions/WebHostExtensions.cs View File

@ -2,23 +2,23 @@
public static class WebHostExtensions public static class WebHostExtensions
{ {
public static bool IsInKubernetes(this IWebHost host)
public static bool IsInKubernetes(this IServiceProvider services)
{ {
var cfg = host.Services.GetService<IConfiguration>();
var cfg = services.GetService<IConfiguration>();
var orchestratorType = cfg.GetValue<string>("OrchestratorType"); var orchestratorType = cfg.GetValue<string>("OrchestratorType");
return orchestratorType?.ToUpper() == "K8S"; return orchestratorType?.ToUpper() == "K8S";
} }
public static IWebHost MigrateDbContext<TContext>(this IWebHost host, Action<TContext, IServiceProvider> seeder) where TContext : DbContext
public static IServiceProvider MigrateDbContext<TContext>(this IServiceProvider services, Action<TContext, IServiceProvider> seeder) where TContext : DbContext
{ {
var underK8s = host.IsInKubernetes();
var underK8s = services.IsInKubernetes();
using var scope = host.Services.CreateScope();
var services = scope.ServiceProvider;
using var scope = services.CreateScope();
var scopedServices = scope.ServiceProvider;
var logger = services.GetRequiredService<ILogger<TContext>>();
var logger = scopedServices.GetRequiredService<ILogger<TContext>>();
var context = services.GetService<TContext>();
var context = scopedServices.GetService<TContext>();
try try
{ {
@ -26,7 +26,7 @@ public static class WebHostExtensions
if (underK8s) if (underK8s)
{ {
InvokeSeeder(seeder, context, services);
InvokeSeeder(seeder, context, scopedServices);
} }
else else
{ {
@ -42,7 +42,7 @@ public static class WebHostExtensions
//migration can't fail for network related exception. The retry options for DbContext only //migration can't fail for network related exception. The retry options for DbContext only
//apply to transient exceptions //apply to transient exceptions
// Note that this is NOT applied when running some orchestrators (let the orchestrator to recreate the failing service) // Note that this is NOT applied when running some orchestrators (let the orchestrator to recreate the failing service)
retry.Execute(() => InvokeSeeder(seeder, context, services));
retry.Execute(() => InvokeSeeder(seeder, context, scopedServices));
} }
logger.LogInformation("Migrated database associated with context {DbContextName}", typeof(TContext).Name); logger.LogInformation("Migrated database associated with context {DbContextName}", typeof(TContext).Name);
@ -56,7 +56,7 @@ public static class WebHostExtensions
} }
} }
return host;
return services;
} }
private static void InvokeSeeder<TContext>(Action<TContext, IServiceProvider> seeder, TContext context, IServiceProvider services) private static void InvokeSeeder<TContext>(Action<TContext, IServiceProvider> seeder, TContext context, IServiceProvider services)


+ 17
- 17
src/Services/Catalog/Catalog.FunctionalTests/CatalogScenarioBase.cs View File

@ -1,24 +1,12 @@
using Microsoft.AspNetCore.Mvc.Testing;
namespace Catalog.FunctionalTests; namespace Catalog.FunctionalTests;
public class CatalogScenariosBase
public class CatalogScenariosBase : WebApplicationFactory<Program>
{ {
public TestServer CreateServer() public TestServer CreateServer()
{ {
var path = Assembly.GetAssembly(typeof(CatalogScenariosBase))
.Location;
var hostBuilder = new WebHostBuilder()
.UseContentRoot(Path.GetDirectoryName(path))
.ConfigureAppConfiguration(cb =>
{
cb.AddJsonFile("appsettings.json", optional: false)
.AddEnvironmentVariables();
});
var testServer = new TestServer(hostBuilder);
testServer.Host
Services
.MigrateDbContext<CatalogContext>((context, services) => .MigrateDbContext<CatalogContext>((context, services) =>
{ {
var env = services.GetService<IWebHostEnvironment>(); var env = services.GetService<IWebHostEnvironment>();
@ -31,7 +19,19 @@ public class CatalogScenariosBase
}) })
.MigrateDbContext<IntegrationEventLogContext>((_, __) => { }); .MigrateDbContext<IntegrationEventLogContext>((_, __) => { });
return testServer;
return Server;
}
protected override IHost CreateHost(IHostBuilder builder)
{
builder.ConfigureAppConfiguration(c =>
{
var directory = Path.GetDirectoryName(typeof(CatalogScenariosBase).Assembly.Location)!;
c.AddJsonFile(Path.Combine(directory, "appsettings.json"), optional: false);
});
return base.CreateHost(builder);
} }
public static class Get public static class Get


Loading…
Cancel
Save