搭建一个UT测试用例过程中关联和继承的选择。
来源:互联网 发布:雨果奖 郝景芳 知乎 编辑:程序博客网 时间:2024/06/05 02:08
首先交代下背景:
在做软件的UT时候,框架使用继承的方式进行搭建,如下图所示:
类CTestCase是一个父类,包含了所有测试中公用的方法。
- 其中虚函数RunTest()作为对外启动测试的虚接口。
- Protect类型的CommonWorks()函数包含了一些必须的公用操作,包含了不可重入的一些变量和操作,将被具体测试用例调用。
子类CConcreteTestCaseA是对软件产品具体某一个特性的测试:
- 其中属性mTestAPara是测试A所独有的针对A特性的一些配置参数;
- SpecialWorksForCaseA是A特性特殊的一些操作封装;
- 继承的方法RunTest用来实现具体的对特性A的操作,包括对特殊操作封装函数SpecialWorksForCaseA的调用;
现在的问题是,新出现了一个特性B,测试它需要调用CConcreteTestCaseA::SpecialWorksForCaseA,
但是目前已知只有极少部分特性的测试需要调用这个操作,其他特性并不需要。
我们可以考虑将B继承自A,构成3层继承关系,如下所示:
这样做的好处在于所有不可重入的变量和方法都会被保护起来。
但是从逻辑上出现了 “B is a A” 的悖论。
另一种选择则是使用关联关系,A与B保持逻辑上的sibling的关系不变,但是使用关联来实现一种类似于单一Composite的结构,如下所示:
这样做的好处在于如下几点:
- 主要的优点是保持了A与B逻辑上的关系正确性,而非“认兄为父”;
- 当A已经存在的时候,不需要更多额外的修改就可以完成这种工作;
- 相比于直接复制SpecialWorksForCaseA中的操作,当A逻辑发生改变的时候,更加容易更新;
- 相比于将SpecialWorksForCaseA提取到父类的CommonWorks的做法,缩减了父类的复杂性和规模,逻辑上成立。
缺点在于:
- 当A中的mTestArgs依赖于父类的mTestConfiguration时候,类CaseA的实例化需要增加复杂度。
当然,还有更好的方法,永远有更好的方法,不是么?
0 0
- 搭建一个UT测试用例过程中关联和继承的选择。
- 测试过程之UT-IT-ST的区别
- DevStack环境的Python版本升级和UT环境搭建
- UT测试框架cxxtest和gtest对比
- sql关联表选择的一个例子
- java中组合和继承的选择使用
- 组合和继承的选择
- VLC搭建RTSP服务器和客户端的测试过程
- openflow搭建过程和安装过程中可能的问题
- 利用TD将测试过程中发现的Bug与需求关联
- 基础模型搭建过程中一个很严重的问题
- Hibernate的关联继承(一个令人崩溃的bug)
- UT阶段测试观点
- UT测试观点
- JAVA中关于继承和隐藏的一个另类问题。
- 【测试算法】测试基础之测试用例的选择
- Java中合成与继承的选择
- qte和显示设备关联的过程
- 音频编码基础
- n=100,用递归实现:n-(n-1)+(n-2)-(n-3)........2-1;
- c++中的引用
- TCP/IP笔记 四.应用层(1)——DNS
- atomikos JTA 源码解读
- 搭建一个UT测试用例过程中关联和继承的选择。
- OBGradientView 处理渐变
- do {...} while (0) 的用途汇总(欢迎补充)
- TCP/IP笔记 四.应用层(2)——FTP
- Afaria 生产环境部署需要考虑的一些问题
- TCP/IP笔记 四.应用层(3)——HTTP
- 一个“轻量级” C 语言协程库
- Bootstrap知多少
- LINQ学习心得