mirror of
https://github.com/bitwarden/server.git
synced 2025-06-07 11:40:31 -05:00

Adds a SqlServerApiApplicationFactory which allows you to run api tests using SqlServer. Currently a new database is create and destroyed for each test. In the future we'd like a more optimized way to do this. The database logic is abstracted away in a ITestDatabase interface which handles the configuration, migration and teardown.
42 lines
1.2 KiB
C#
42 lines
1.2 KiB
C#
using Bit.Infrastructure.EntityFramework.Repositories;
|
|
using Microsoft.Data.Sqlite;
|
|
using Microsoft.EntityFrameworkCore;
|
|
using Microsoft.Extensions.DependencyInjection;
|
|
|
|
namespace Bit.IntegrationTestCommon;
|
|
|
|
public class SqliteTestDatabase : ITestDatabase
|
|
{
|
|
private SqliteConnection SqliteConnection { get; set; }
|
|
|
|
public SqliteTestDatabase()
|
|
{
|
|
SqliteConnection = new SqliteConnection("DataSource=:memory:");
|
|
SqliteConnection.Open();
|
|
}
|
|
|
|
public void AddDatabase(IServiceCollection serviceCollection)
|
|
{
|
|
serviceCollection.AddScoped(s => new DbContextOptionsBuilder<DatabaseContext>()
|
|
.UseSqlite(SqliteConnection)
|
|
.UseApplicationServiceProvider(s)
|
|
.Options);
|
|
}
|
|
|
|
public void Migrate(IServiceCollection serviceCollection)
|
|
{
|
|
var serviceProvider = serviceCollection.BuildServiceProvider();
|
|
using var scope = serviceProvider.CreateScope();
|
|
var services = scope.ServiceProvider;
|
|
var context = services.GetRequiredService<DatabaseContext>();
|
|
|
|
context.Database.EnsureDeleted();
|
|
context.Database.EnsureCreated();
|
|
}
|
|
|
|
public void Dispose()
|
|
{
|
|
SqliteConnection.Dispose();
|
|
}
|
|
}
|