如何解决每次测试后,asp-net核心集成测试回滚事务
我已经将此文档用于集成测试:asp.net core integration tests,这是我的简化集成测试:
public class ApplicationControllerTests : IClassFixture<CustomWebApplicationFactory<Startup>>
{
private readonly CustomWebApplicationFactory<Startup> _factory;
public ApplicationControllerTests(CustomWebApplicationFactory<Startup> factory)
{
_factory = factory;
}
[Fact]
public async Task AcceptOffer_WhenCalled_ShouldReturnSuccess()
{
var httpClient = factory.CreateClient();
var acceptOfferRequest = new AcceptOfferRequest
{
OfferId = 1,OfferType = 1
}.ToJsonStringContent();
var response = await httpClient.PostAsync("/api/v1/Application/AcceptOffer",acceptOfferRequest);
response.EnsureSuccess();
Assert.Equal(HttpStatusCode.OK,response.StatusCode);
}
}
如您所见,我正在向“ / api / v1 / Application / AcceptOffer” API发送HTTP请求,该API更新数据库中的某些实体,如果一切正常,则返回状态代码200。
测试后,我想像测试前一样清理数据库。为此,我想将测试放入事务中,并在每个测试完成后回滚。当前的实现可能吗?删除和重新创建数据库的成本很高,这就是为什么我要将测试放入事务中的原因。
我正在使用带有实体框架ORM的MS SQL数据库。
一种解决方案是使用单例DbContext,然后将所有测试包装在事务中,但是问题是SQL不支持嵌套事务,如果API也使用事务,则会抛出运行时异常。 另一种解决方案是使用C#的TransactionScope,但它不适用于SQL事务,也不适用于其他线程。
解决方法
好的,正如我发现的那样,没有很好的方法或方法可以使用事务解决此问题。我编写了全局脚本,而不是事务,而是在其中手动截断所有表并在每次测试后执行它。显然,它比删除并重新创建数据库要快。
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。