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

transactionscope mysql_c# – 嵌套的TransactionScope在测试中失败我正在使用MSTest通过MySQLConnector和使用EntityFramework4.3对MysqL5.5.19数据库运行一些自动化测试.我正在尝试在我的数据库访问类库中使用TransactionScope在需要时执行回滚.另外,在我的测试代码中,我希望在每次测试之前使用TransactionScope将数据库恢复到已知状态.我使用TestInitialize和TestCleanup…

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

我正在使用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.net/161933.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • idea打开不了项目_idea为什么打不开

    idea打开不了项目_idea为什么打不开最近做项目的时候发现一个有趣的事情。公司以前的项目代码拉取下来之后用idea没法打开。如上图open之后没反应。打不开。找了很多资料没发现是什么原因导致的,只有这一个项目打不开,其他项目都能正常打开、编译,同时idea无任何提示。这个解决办法呢我尝试是在下图这个页面直接将项目拖进去,确实解决了问题,能够正常打开编译了。此方法目前来看2019.3.4和2020.2版本试过是可以的,但是在2017.12版本上此方法不行。如有大神知道原因请留言,小弟感激不尽…

    2022年9月1日
    3
  • 在线更换背景网站(白色背景换为蓝色背景证件照)[通俗易懂]

    在线更换背景网站(白色背景换为蓝色背景证件照)

    2022年2月10日
    58
  • Excel中文转拼音【真正的完整版】 拼音 驼峰命名专用

    Excel中文转拼音【真正的完整版】 拼音 驼峰命名专用一、打开Excel按  Alt+F11进入VB编程模式,选择“模块” 二、把下面的代码复制粘贴到“通用”下方的空白处Functionpinyin(pAsString)AsString’*************************************’版本说明:转载请保留此段注释’更新时间:2018年8月28日’作者:上海五航航空技…

    2022年6月21日
    31
  • ETH硬分叉降低了显卡矿机的挖矿收益吗?

    ETH硬分叉降低了显卡矿机的挖矿收益吗?“北京时间2019年3月1日凌晨3:52分,ETH完成了君士坦丁堡硬分叉升级。这场从2018年8月份就开始计划的硬分叉,几经波折,但最终是平稳顺利的。虽然对比其他主流币种轰轰烈烈的硬分叉,ETH这次硬分叉显得过于平淡,但还是有很多矿工朋友想知道它是否降低了ETH的挖矿收益,未来挖矿收益如何变化,显卡矿机未来的出路在哪里?”笔者根据最近一年的ETH挖矿难度、挖矿收益、币价等变化情况,做了一些…

    2022年6月9日
    44
  • vue.config.js打包优化(有效)「建议收藏」

    vue.config.js打包优化(有效)「建议收藏」//百度上的资料五花八门让人眼花缭乱,别急,这时候我替你亲身经历了,有需要的可以参考下,先上效果图,以免你们以为我吹牛逼,嘻嘻未优化之前的//感觉太大了抬它优化之后的废话不多说了,上代码是重点这些是必要的下载/*cnpminstallimage-webpack-loader–save-devcnpminstallcompression-webpack-plugin–save-devcnpminstalluglifyjs-webpack-plugin–sa

    2022年6月12日
    89
  • NetSetMan Pro(ip快速切换工具)官方中文版V5.1.0 | 电脑ip切换软件下载

    NetSetMan Pro(ip快速切换工具)官方中文版V5.1.0 | 电脑ip切换软件下载NetSetManPro是一款短小精悍且方便实用的网络ip快速切换工具,界面简洁易于使用,可以轻松地在用户的预配置配置文件之间切换,可以设置六组不同的网络参数值,一目了然地管理所有网络设置,预先设置好一切,让使用者可以针对不同的网络环境,而调用不同的参数,可以快速设置计算机IP地址、子网掩码、默认网关、DNS、计算机名、DNS域、工作组、WINS、打印机等,如果大家需要一款电脑ip切换软件的话,威航软件园认为NetSetManPro是一个不错的选择哦。

    2022年10月28日
    0

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号