前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >transactionscope mysql_c# – 嵌套的TransactionScope在测试中失败

transactionscope mysql_c# – 嵌套的TransactionScope在测试中失败

作者头像
全栈程序员站长
发布2022-09-15 12:57:31
2K0
发布2022-09-15 12:57:31
举报
文章被收录于专栏:全栈程序员必看

大家好,又见面了,我是你们的朋友全栈君。

我正在使用MSTest通过

MySQL Connector和使用EntityFramework 4.3对MysqL 5.5.19数据库运行一些自动化测试.

我正在尝试在我的数据库访问类库中使用TransactionScope在需要时执行回滚.另外,在我的测试代码中,我希望在每次测试之前使用TransactionScope将数据库恢复到已知状态.我使用TestInitialize和TestCleanup方法来完成此任务.那些看起来像这样:

[TestInitialize()]

public void MyTestInitialize()

{

testTransScope = new TransactionScope(TransactionScopeOption.RequiresNew);

}

[TestCleanup()]

public void MyTestCleanup()

{

Transaction.Current.Rollback();

testTransScope.Dispose();

}

基于在Initialize函数中构造TransactionScope对象,我相信我应该得到一个新的事务范围(没有“环境”存在,所以我相信这个“​​.RequiresNew”在技术上并不重要“.required”会产生相同的结果.由于我没有指定超时值,它为我提供了默认超时,我理解为60秒.我给定测试运行的时间充足.

我有一个名为AddDessert(DessertBiz dessertBizObject)的函数,其部分看起来像这样:

using (var transScope = new TransactionScope(TransactionScopeOption.required))

{

try

{

// …

context.Desserts.Add(dessert);

context.SaveChanges();

var dessertId = dessert.Id;

DoOtherDessertStuff(dessertId,dessertBizObject);

transScope.Complete();

}

catch (InvalidOperationException ex)

{

Console.WriteLine(ex.ToString());

}

}

并且我的一个测试调用了这个函数.

由于我在这里指定了TransactionScopeOption.required,我希望它将使用MyTestInitialize函数创建的“环境”事务范围.

我的测试安排使这个DoOtherDessertStuff函数失败并抛出异常,所以调用transScope.Complete();不会发生,并且在退出AddDessert函数中的using块时会自动进行回滚.

我在这里遇到的问题是,由于它使用MyTestInitialize函数中创建的环境事务范围,因此我的测试Assert调用不会发生,因为事务范围回滚发生了 – 至少这是我认为正在发生的事情.我验证了Transaction.Current.TransactionInformation.Statusis TransactionStatus.Aborted,所以我觉得很确定这是发生了什么.

太棒了,所以我想我会改变我的AddDesert方法看起来与上面完全一样,除了我会嵌套一个事务范围而不是使用环境范围,一些我使用的行看起来像这样:

using (var transScope = new TransactionScope(TransactionScopeOption.RequiresNew))

这里的意图是我可以嵌套这些事务范围,让我的生产代码中的回滚发生,然后仍然在我的测试代码中检查我的Asserts.

但我发现我得到以下错误:

System.IO.IOException:无法从传输连接读取数据:连接尝试失败,因为连接方在一段时间后没有正确响应,或者由于连接的主机无法响应而建立的连接失败.

想法?

发布者:全栈程序员栈长,转载请注明出处:https://javaforall.cn/161933.html原文链接:https://javaforall.cn

本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
相关产品与服务
数据库
云数据库为企业提供了完善的关系型数据库、非关系型数据库、分析型数据库和数据库生态工具。您可以通过产品选择和组合搭建,轻松实现高可靠、高可用性、高性能等数据库需求。云数据库服务也可大幅减少您的运维工作量,更专注于业务发展,让企业一站式享受数据上云及分布式架构的技术红利!
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档