Итак, я пытаюсь создать интеграционный тест с заранее заданными данными в моем dbcontext, но по какой-то причине он не сохраняет мою запись в базу данных и дает мне 404, не найденных после того, как я получу свой ответ. Рад расширить или уточнить что-нибудь, если это необходимо.
Приветствия
[Fact]
public async Task GetPet_ReturnsResourceWithAccurateFields()
{
var fakePet = new FakePet { }.Generate();
fakePet.PetId = 1;
var appFactory = new WebApplicationFactory<StartupAutomatedTesting>()
.WithWebHostBuilder(builder =>
{
builder
.ConfigureServices(services =>
{
services.Remove(new ServiceDescriptor(typeof(MyDbContext),
typeof(MyDbContext)));
services.AddDbContext<MyDbContext>(options =>
{
options.UseInMemoryDatabase("TestDb");
});
var serviceProvider = services
.AddEntityFrameworkInMemoryDatabase()
.BuildServiceProvider();
using (var scope = serviceProvider.CreateScope())
{
var context = scope.ServiceProvider.GetRequiredService<MyDbContext>();
context.Database.EnsureCreated();
context.Pets.AddRange(fakePet);
context.SaveChanges();
}
});
});
var testingClient = appFactory.CreateClient();
var result = await testingClient.GetAsync($"/v1/Pets/{fakePet.PetId}");
var responseContent = await result.Content.ReadAsStringAsync();
var response = JsonConvert.DeserializeObject<PetDto>(responseContent);
// Assert
response.Name.Should().Be(fakePet.Name);
response.Age.Should().Be(fakePet.Age);
}