搭建一个UT测试用例过程中关联和继承的选择
作者:网络转载 发布时间:[ 2014/2/7 10:17:16 ] 推荐标签:测试用例 继承 关联
首先交代下背景:
在做软件的UT时候,框架使用继承的方式进行搭建,如下图所示:
类CTestCase是一个父类,包含了所有测试中公用的方法。
其中虚函数RunTest()作为对外启动测试的虚接口。
Protect类型的CommonWorks()函数包含了一些必须的公用操作,包含了不可重入的一些变量和操作,将被具体测试用例调用。
子类CConcreteTestCaseA是对软件产品具体某一个特性的测试:
其中属性mTestAPara是测试A所独有的针对A特性的一些配置参数;
SpecialWorksForCaseA是A特性特殊的一些操作封装;
继承的方法RunTest用来实现具体的对特性A的操作,包括对特殊操作封装函数SpecialWorksForCaseA的调用;
现在的问题是,新出现了一个特性B,测试它需要调用CConcreteTestCaseA::SpecialWorksForCaseA,
但是目前已知只有极少部分特性的测试需要调用这个操作,其他特性并不需要。
我们可以考虑将B继承自A,构成3层继承关系,如下所示:
这样做的好处在于所有不可重入的变量和方法都会被保护起来。
但是从逻辑上出现了 “B is a A” 的悖论。
相关推荐
更新发布
功能测试和接口测试的区别
2023/3/23 14:23:39如何写好测试用例文档
2023/3/22 16:17:39常用的选择回归测试的方式有哪些?
2022/6/14 16:14:27测试流程中需要重点把关几个过程?
2021/10/18 15:37:44性能测试的七种方法
2021/9/17 15:19:29全链路压测优化思路
2021/9/14 15:42:25性能测试流程浅谈
2021/5/28 17:25:47常见的APP性能测试指标
2021/5/8 17:01:11