测试疑难解答与遗留项目测试指南
1. 测试中的常见问题及解决方法
在测试驱动开发(TDD)过程中,我们常常会遇到各种问题,尤其是当测试失败但代码看起来正常时,这会让开发者感到十分沮丧。以下是一些常见问题及解决建议。
1.1 模拟对象导致的脆弱测试
模拟对象常常会对在其上调用的方法产生严格的预期,从而创建出脆弱的测试。如果在被测试的代码中添加了意外的方法调用,仅仅因为调用了意外的方法,就可能导致模拟对象测试失败。例如,对登录过滤器的更改可能会导致数百个测试失败,因为模拟用户通过登录过滤器时会受到新调用的影响。
解决方法:根据所使用的模拟包,可以使用类似 Mocha 的 mock_everything() 方法,该方法会自动为任何意外的方法调用返回 nil ,而不会触发错误。
1.2 测试失败原因排查
当测试失败且不清楚原因时,可以从以下几个方面进行排查:
- 查找变更内容 :当之前通过的测试失败时,意味着某些内容发生了变化。可能是代码、系统或测试本身。可以查看最近的更改,Git 的 bisect 工具可以自动完成此操作,也可以在选择的源代码控制查看器中手动查看。频繁提交代码到源代码控制(尤其是使用 Git 进行本地提交)有助于使更改更加细化,便于查找问题。同时,要注意 fixture 文件的更改可能会导致测试失败,数据库迁移时, rake 会自动将新结构加载到测试数据库,但 spec 、 cucumber
超级会员免费看
订阅专栏 解锁全文
1058

被折叠的 条评论
为什么被折叠?



