"Test-infrastructure-improvements"
This commit is contained in:
parent
7c522535c6
commit
6e5f5ae279
@ -10,6 +10,13 @@ using LittleShop.Services;
|
|||||||
using Microsoft.Extensions.DependencyInjection.Extensions;
|
using Microsoft.Extensions.DependencyInjection.Extensions;
|
||||||
using Moq;
|
using Moq;
|
||||||
using System.Linq;
|
using System.Linq;
|
||||||
|
using Microsoft.AspNetCore.Authentication;
|
||||||
|
using Microsoft.Extensions.Configuration;
|
||||||
|
using Microsoft.Extensions.Options;
|
||||||
|
using System.Collections.Generic;
|
||||||
|
using System.Security.Claims;
|
||||||
|
using System.Text.Encodings.Web;
|
||||||
|
using System.Threading.Tasks;
|
||||||
|
|
||||||
namespace LittleShop.Tests.Infrastructure;
|
namespace LittleShop.Tests.Infrastructure;
|
||||||
|
|
||||||
@ -29,9 +36,52 @@ public class TestWebApplicationFactory : WebApplicationFactory<Program>
|
|||||||
options.UseInMemoryDatabase("InMemoryDbForTesting")
|
options.UseInMemoryDatabase("InMemoryDbForTesting")
|
||||||
.ConfigureWarnings(warnings => warnings.Default(WarningBehavior.Ignore)));
|
.ConfigureWarnings(warnings => warnings.Default(WarningBehavior.Ignore)));
|
||||||
|
|
||||||
|
// Add test configuration
|
||||||
|
var configuration = new ConfigurationBuilder()
|
||||||
|
.AddInMemoryCollection(new Dictionary<string, string>
|
||||||
|
{
|
||||||
|
{"Jwt:Key", "test-key-that-is-at-least-32-characters-long-for-security"},
|
||||||
|
{"Jwt:Issuer", "LittleShop"},
|
||||||
|
{"Jwt:Audience", "LittleShop"},
|
||||||
|
{"SilverPay:BaseUrl", "http://test.example.com"},
|
||||||
|
{"SilverPay:ApiKey", "test-api-key"},
|
||||||
|
{"CORS:AllowedOrigins:0", "http://localhost:3000"}
|
||||||
|
})
|
||||||
|
.Build();
|
||||||
|
|
||||||
|
services.AddSingleton<IConfiguration>(configuration);
|
||||||
|
|
||||||
|
// Add test authentication
|
||||||
|
services.AddAuthentication("Test")
|
||||||
|
.AddScheme<AuthenticationSchemeOptions, TestAuthenticationHandler>("Test", options => { });
|
||||||
|
|
||||||
// Mock external services that might cause issues in tests
|
// Mock external services that might cause issues in tests
|
||||||
services.Replace(ServiceDescriptor.Scoped<IPushNotificationService>(_ => Mock.Of<IPushNotificationService>()));
|
services.Replace(ServiceDescriptor.Scoped<IPushNotificationService>(_ => Mock.Of<IPushNotificationService>()));
|
||||||
services.Replace(ServiceDescriptor.Scoped<ITelegramBotManagerService>(_ => Mock.Of<ITelegramBotManagerService>()));
|
services.Replace(ServiceDescriptor.Scoped<ITelegramBotManagerService>(_ => Mock.Of<ITelegramBotManagerService>()));
|
||||||
|
services.Replace(ServiceDescriptor.Scoped<ISilverPayService>(_ => Mock.Of<ISilverPayService>()));
|
||||||
|
services.Replace(ServiceDescriptor.Scoped<IRoyalMailService>(_ => Mock.Of<IRoyalMailService>()));
|
||||||
|
services.Replace(ServiceDescriptor.Scoped<ITeleBotMessagingService>(_ => Mock.Of<ITeleBotMessagingService>()));
|
||||||
|
services.Replace(ServiceDescriptor.Scoped<IMessageDeliveryService>(_ => Mock.Of<IMessageDeliveryService>()));
|
||||||
|
|
||||||
|
// Keep real implementations for business logic services
|
||||||
|
services.TryAddScoped<IAuthService, AuthService>();
|
||||||
|
services.TryAddScoped<ICategoryService, CategoryService>();
|
||||||
|
services.TryAddScoped<IProductService, ProductService>();
|
||||||
|
services.TryAddScoped<IOrderService, OrderService>();
|
||||||
|
services.TryAddScoped<IReviewService, ReviewService>();
|
||||||
|
services.TryAddScoped<ICustomerService, CustomerService>();
|
||||||
|
services.TryAddScoped<ISystemSettingsService, SystemSettingsService>();
|
||||||
|
services.TryAddScoped<IVariantCollectionService, VariantCollectionService>();
|
||||||
|
services.TryAddScoped<IShippingRateService, ShippingRateService>();
|
||||||
|
services.TryAddScoped<IBotService, BotService>();
|
||||||
|
services.TryAddScoped<IBotMetricsService, BotMetricsService>();
|
||||||
|
services.TryAddScoped<IBotContactService, BotContactService>();
|
||||||
|
services.TryAddScoped<ICustomerMessageService, CustomerMessageService>();
|
||||||
|
services.TryAddScoped<IBotActivityService, BotActivityService>();
|
||||||
|
services.TryAddScoped<IProductImportService, ProductImportService>();
|
||||||
|
|
||||||
|
// Add validation service
|
||||||
|
services.TryAddSingleton<ConfigurationValidationService>();
|
||||||
|
|
||||||
// Build service provider
|
// Build service provider
|
||||||
var sp = services.BuildServiceProvider();
|
var sp = services.BuildServiceProvider();
|
||||||
@ -66,4 +116,29 @@ public class TestWebApplicationFactory : WebApplicationFactory<Program>
|
|||||||
// Seed test data will be added as needed for specific tests
|
// Seed test data will be added as needed for specific tests
|
||||||
context.SaveChanges();
|
context.SaveChanges();
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
public class TestAuthenticationHandler : AuthenticationHandler<AuthenticationSchemeOptions>
|
||||||
|
{
|
||||||
|
public TestAuthenticationHandler(IOptionsMonitor<AuthenticationSchemeOptions> options,
|
||||||
|
ILoggerFactory logger, UrlEncoder encoder)
|
||||||
|
: base(options, logger, encoder)
|
||||||
|
{
|
||||||
|
}
|
||||||
|
|
||||||
|
protected override Task<AuthenticateResult> HandleAuthenticateAsync()
|
||||||
|
{
|
||||||
|
var claims = new[]
|
||||||
|
{
|
||||||
|
new Claim(ClaimTypes.Name, "TestUser"),
|
||||||
|
new Claim(ClaimTypes.NameIdentifier, "123"),
|
||||||
|
new Claim(ClaimTypes.Role, "Admin")
|
||||||
|
};
|
||||||
|
|
||||||
|
var identity = new ClaimsIdentity(claims, "Test");
|
||||||
|
var principal = new ClaimsPrincipal(identity);
|
||||||
|
var ticket = new AuthenticationTicket(principal, "Test");
|
||||||
|
|
||||||
|
return Task.FromResult(AuthenticateResult.Success(ticket));
|
||||||
|
}
|
||||||
}
|
}
|
||||||
Loading…
Reference in New Issue
Block a user