gpt4 book ai didi

c# - .Net Core Connection 目前有事务登记

转载 作者:行者123 更新时间:2023-12-03 16:51:54 26 4
gpt4 key购买 nike

我正在使用 .Net Core 2.1 编写集成测试我有一个看起来像这样的测试:

private TransactionScope scope;

[TestCleanup]
public void TestCleanup()
{
this.scope.Dispose();
}

[TestInitialize]
public void VerifyUsersHaveBeenSeeded()
{
var transactionOptions = new TransactionOptions {
IsolationLevel = IsolationLevel.ReadCommitted
};
//I've also tried using TransactionScopeOption.Required
this.scope = new TransactionScope(TransactionScopeOption.RequiresNew,
transactionOptions);
}

//Note I am using an MDF file during Testing.
protected AstootContext GetContext()
{
var optionsBuilder = new DbContextOptionsBuilder<AstootContext>();
optionsBuilder.UseSqlServer(this.ASTOOT_CONNECTION_STRING);
var context = new AstootContext(optionsBuilder.Options);
return context;
}


[TestMethod]
public async Task RestEzServiceVerifyUpdate()
{
var context = this.GetContext();
var expectedResult = context.Users.First();

var restEzService = GetDefaultService<User, UserDTO>(context);
var key = new object[] { expectedResult.Id };

var dto = await restEzService.Get(key);

var updatedName = "Updated";
dto.FirstName = updatedName;

var updatedDTO = await restEzService.Update(key, dto);
Assert.IsTrue(updatedDTO.FirstName == updatedName);
updatedDTO.Should().BeEquivalentTo(expectedResult,
o => o.Excluding(x => x.UniqueIdentifier).Excluding(x => x.FirstName));

context.Dispose();
}

更新方法调用:
var entity = await this._context.FindAsync(id).ConfigureAwait(false);
this.applyDTOToEntity(entity, dto);
await this._context.SaveChangesAsync().ConfigureAwait(false);

当它调用保存更改时,我收到一个错误:

System.InvalidOperationException: Connection currently has transaction enlisted. Finish current transaction and retry.



我从上下文中调用的唯一地方是 1. 要在测试中获得预期结果,2. 获取更新的实体,3. 保存更改。

我已将 transactionScopeOptions 设置为 Requires New,为什么会出现此错误?

最佳答案

TransactionScopeOption.RequiresNew尝试创建新事务。您确定在 new TransactionScope 点没有交易吗? .

也许,您需要将其替换为 TransactionScopeOption.Required
你也使用 async/await,所以添加到范围选项 TransactionScopeAsyncFlowOption.Enabled :

using (var scope = new TransactionScope(... ,
TransactionScopeAsyncFlowOption.Enabled))

关于c# - .Net Core Connection 目前有事务登记,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/50959848/

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com