// ========================================================================== // Squidex Headless CMS // ========================================================================== // Copyright (c) Squidex UG (haftungsbeschraenkt) // All rights reserved. Licensed under the MIT license. // ========================================================================== using Microsoft.Data.SqlClient; using Microsoft.EntityFrameworkCore; using Microsoft.EntityFrameworkCore.Diagnostics; using Microsoft.Extensions.DependencyInjection; using PhenX.EntityFrameworkCore.BulkInsert.SqlServer; using Squidex.Domain.Apps.Core.TestHelpers; using Squidex.Hosting; using Squidex.Infrastructure; using Squidex.Infrastructure.Migrations; using Squidex.Infrastructure.Queries; using Squidex.Providers.SqlServer; using Squidex.Providers.SqlServer.Content; using Testcontainers.MsSql; namespace Squidex.EntityFramework.TestHelpers; public class SqlServerFixture(string? reuseId = null) : IAsyncLifetime, ISqlContentFixture { private readonly MsSqlContainer sqlServer = new MsSqlBuilder("vibs2006/sql_server_fts") .WithReuse(true) .WithLabel("reuse-id", reuseId) .Build(); private IServiceProvider services; public IDbContextFactory DbContextFactory => services.GetRequiredService>(); public IDbContextNamedFactory DbContextNamedFactory => services.GetRequiredService>(); public async ValueTask InitializeAsync() { await sqlServer.StartAsync(TestContext.Current.CancellationToken); await sqlServer.ExecScriptAsync($"create database squidex;", TestContext.Current.CancellationToken); var connectionString = GetConnectionString(); services = new ServiceCollection() .AddPooledDbContextFactory(builder => { builder.UseBulkInsertSqlServer(); builder.UseSqlServer(connectionString, options => { options.UseNetTopologySuite(); }); }) .AddNamedDbContext((builder, name) => { builder.UseBulkInsertSqlServer(); builder.UseSqlServer(connectionString); builder.ConfigureWarnings(w => w.Ignore(RelationalEventId.PendingModelChangesWarning)); }) .AddSingleton() .AddSingletonAs>().Done() .AddSingleton(TestUtils.DefaultSerializer) .AddSingleton>() .BuildServiceProvider(); foreach (var service in services.GetRequiredService>()) { await service.InitializeAsync(default); } } public async ValueTask DisposeAsync() { foreach (var service in services.GetRequiredService>()) { await service.ReleaseAsync(default); } await sqlServer.StopAsync(TestContext.Current.CancellationToken); } private string GetConnectionString() { var builder = new SqlConnectionStringBuilder(sqlServer.GetConnectionString()) { InitialCatalog = "squidex", }; return builder.ConnectionString; } }