以测试驱动开发,打造高质量软件
在软件开发的征程中,质量始终是我们追求的核心目标。曾经,我们面临着一个不稳定且漏洞百出的遗留应用程序,这促使我们下定决心要生产出高质量的软件。下面,就和大家分享我们在提升软件质量过程中的实践与经验。
1. 聚焦可测试性
在 2003 年末,由于没有自动化回归测试,我们为 Web 应用的所有关键功能编写了手动测试脚本。每两周的冲刺阶段,整个团队,包括程序员、数据库管理员、系统管理员和 Scrum 主管,都会花费一两天时间执行这些手动测试。这一活动极大地激发了团队成员设计可测试代码的积极性,也促使大家去探索不同层面自动化回归测试的有效方法。
我们致力于在单元层面采用测试驱动开发(TDD),同时运用更高级别的面向业务的测试来指导编码。我们的目标是实现 100% 的回归测试自动化,以将技术债务降至最低,及时获得代码更改是否会破坏功能的反馈,并实现持续重构。更重要的是,自动化所有回归测试能为关键的探索性测试留出更多时间,提前发现新功能带来的意外影响并及时纠正,这是非常有价值的。
2. 自动化测试
经过几周的研究和讨论,团队决定未来编写的所有新代码都采用分层架构,并且在设计时就考虑自动化测试。和许多刚接触 TDD 的团队一样,我们的程序员发现为业务逻辑、展示逻辑和数据库访问混合在一起的遗留代码编写单元测试非常困难,甚至整个 TDD 过程都颇具挑战,这就是 Brian Marick 所说的“痛苦之峰”。随着团队对 TDD 的熟练掌握,程序员在更改遗留代码和编写新架构代码时都会编写单元测试。
我们团队很认同 Mike Cohn 的“测试自动化金字塔”理念。我们知道在单元层面进行测试自动化的投资回报率最
超级会员免费看
订阅专栏 解锁全文
2万+

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



