我们听说过很多关于测试驱动开发(TDD)的内容。那么什么是ATDD?
ATDD代表验收测试驱动开发,这是一种定义验收标准并创建自动化测试来验证是否满足这些标准的软件开发方法。ATDD是一种协作方法,涉及客户、开发人员和测试人员共同努力创建对需要开发什么以及如何测试有共同的理解。
ATDD 受到精益开发原则的影响,其中一个原则是减少流程中的浪费。预先创建验收测试可以减少从测试到编码的环回,从而减少浪费。此外,通过让客户参与规范阶段并创建反映客户需求的自动化验收测试,开发团队可以确信他们正在构建正确的产品。通过创建验证软件功能的自动化验收测试,开发团队可以在开发过程的早期发现错误和问题,从而更容易且经济有效地修复它们。
为什么需要 ATDD?
ATDD 鼓励客户、开发团队和测试人员之间的协作,从而形成对项目需求的共同理解。这有助于确保正在开发的软件满足客户的需求,并减少误解和沟通不畅的可能性。
通过预先定义验收标准并创建自动化测试来验证它们,ATDD 有助于确保正在开发的软件满足所需的质量标准。这可以减少软件中的错误和问题的数量,从而产生更高质量的产品。
使用 ATDD,可以在编写代码之前创建测试,从而向开发团队提供有关代码是否满足要求的即时反馈。这种早期反馈有助于在开发过程中尽早发现问题,从而减少总体开发时间和成本。
通过在开发过程的早期发现问题,ATDD 可以帮助减少所需的返工。这可以节省时间并降低项目成本。
ATDD 通过鼓励定期验收标准和测试用例审查来促进持续改进。这可以帮助确定需要改进的领域并确保软件不断满足客户的需求。
每个人都应该练习 ATDD 吗?
ATDD 可用于各种软件开发环境,包括敏捷、瀑布和混合方法。然而,ATDD 通常与敏捷方法相关,例如 Scrum 和极限编程 (XP),它通常用作规划和评估过程的一部分。
一个金融软件开发团队使用 ATDD 开发了新的信用卡支付系统。他们与债权人和银行专业人士合作,确定接受标准,其中包括输入申请人信息、计算未偿信用卡付款、根据可用余额批准或拒绝付款、限制或阻止未来购买等的能力。然后,团队创建了自动化验收测试来验证系统是否满足这些要求。
测试框架
通过自动化测试来验证验收标准,这些测试可以使用任何框架来编写 - Cucumber、FitNesse、JBehave、Gauge 等。
协作工具
开发团队、客户和测试人员之间的协作是 ATDD 的目标。团队可能需要使用 JIRA、Trello 和 Asana 等软件来促进更顺畅的协作并跟踪进度。
持续集成 (CI) 工具
ATDD 重视持续集成。为了确保更改得到测试并及时合并到主代码库中,可以使用 Jenkins、CircleCI 和 Travis CI 等 CI 解决方案来自动化构建和测试过程。
版本控制系统
对于 ATDD 的实现,Git、SVN 等版本控制系统是必不可少的。它们使团队能够有效地协调和管理代码库更改。
模拟和存根框架
ATDD 要求在编写任何代码之前创建验收测试。团队可以在开发过程的早期建立验收测试,方法是使用 Mockito 和 EasyMock 等模拟和存根框架来创建假对象和存根来模拟依赖关系。
虽然 ATDD 为开发团队带来了许多优势,但团队也应该意识到潜在的缺点:
创建验收测试可能需要花费大量时间,并且保持最新状态也很困难。此外,随着代码库的变化,团队必须确保测试是最新的。这可能很困难,特别是对于复杂且大型的应用程序。
编写和维护 ATDD 验收测试需要一定的技术能力。所有团队成员可能都无法处理这个问题,尤其是那些没有太多编码经验的人。
验收测试不是灵丹妙药,但它们可以在开发过程的早期发现缺陷。然而,即使进行了验收测试,错误仍然可能会过去,特别是如果它们没有涵盖所有情况。
ATDD 需要利益相关者、测试人员和开发人员之间进行强有力的协调。如果团队缺乏有效的沟通和团队合作能力,则可能不适合 ATDD。
结论
总之,如果实施正确,ATDD可以在软件质量、客户满意度和交付时间方面带来可观的收益。然而,ATDD实施的失败可归因于缺乏明确定义的验收标准、沟通和协作效率低下以及对该技术缺乏熟悉。