Код: Выделить всё
using Microsoft.EntityFrameworkCore;
var builder = WebApplication.CreateBuilder(args);
var constr = $"DataSource={Guid.NewGuid()}.db";
builder.Services.AddDbContext(o => o.UseSqlite(constr));
var app = builder.Build();
app.Run();
public record Person(int Id);
public class AppDbContext(DbContextOptions o) : DbContext(o)
{
public DbSet People { get; set; }
}
public interface IWebApiMarker;
Код: Выделить всё
#define SYNC
using Microsoft.AspNetCore.Mvc.Testing;
using Microsoft.Extensions.DependencyInjection;
namespace WebApi.Test;
public class Test_1 : BaseTest
{
[Fact] public async Task Test() => await Task.Delay(2000);
}
#if SYNC
public abstract class BaseTest : IDisposable
#else
public abstract class BaseTest : IAsyncDisposable
#endif
{
private readonly WebApplicationFactory _factory;
protected BaseTest()
{
_factory = new WebApplicationFactory();
using var scope = _factory.Services.CreateScope();
var db = scope.ServiceProvider.GetRequiredService();
db.Database.EnsureCreated();
}
#if SYNC
public void Dispose()
{
using var scope = _factory.Services.CreateScope();
var db = scope.ServiceProvider.GetRequiredService();
db.Database.EnsureDeleted();
_factory.Dispose();
}
#else
public async ValueTask DisposeAsync()
{
using var scope = _factory.Services.CreateScope();
var db = scope.ServiceProvider.GetRequiredService();
db.Database.EnsureDeleted();
await _factory.DisposeAsync();
}
#endif
}
Неудачные попытки
- Кэширование базы данных разрешено в BaseTest() как частная база данных AppDbContext только для чтения и повторное ее использование (чтобы убедиться в этом) это тот же объект) в DisposeAsync() не помогает.
- Замена db.Database.EnsureDeleted() на await db.Database.EnsureDeletedAsync()< /code> не помогает.
- Вызов DisposeAsync() в тестовом методе, [Факт] public async Task Test() => await DisposeAsync(); не помогает. Он выдает исключение:
Подробнее здесь: https://stackoverflow.com/questions/788 ... -fails-why
Мобильная версия