验收准则(AC,Acceptance Criteria)和测试用例(TC,Test Cases)都是敏捷中每个Story的组成部分,两者既有区别,也有相互交叉的地方。在实际操作中,往往很难将两者完全区分开来,但我们还是很有必要搞清楚两者的异同。
下面是我对两者关系的理解:
1. AC是Story内容的详尽解释和说明,TC则是执行测试参考的内容(包括执行步骤等);
2. AC是story交互时候必须满足的一组条件,TC则是sign-off一个story前所必须执行的测试;
3. AC的每一条都应体现出业务价值,TC应尽量覆盖到可能出问题的地方;
4. AC由业务分析师根据客户的需求来编写,TC是由测试人员根据AC来编写;
5. AC需要客户、业务分析师以及至少一名技术人员来共同review,TC需要测试人员、业务分析师来review;
6. AC提供测试的边界条件,TC是AC的具体实例,为AC服务;
7. AC是story的功能列表,TC需要包括所有AC的内容,并将其细化,还应包括很多negivate的用例,以确保系统对异常能正确的处理。
最佳实践是业务分析师根据客户需求编写AC,邀请客户、技术人员来一起review,需要客户来确认,然后测试人员根据被客户确认过的AC来编写TC,再邀请项目组所有测试人员和业务分析师(开发人员可选)来review,并最终确定。
文章来源于领测软件测试网 https://www.ltesting.net/