6. Jenkins使用Node调度各种测试用例

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了6. Jenkins使用Node调度各种测试用例相关的知识,希望对你有一定的参考价值。

参考技术A 使用Jenkins来调度不同种类的测试用例,需要先改造测试用例:

1. 设备的选择通过环境变量传递给UDID

2. 当并行执行case时,Chromedriver的端口,appnium server的端口等会发生冲突,所以不能全都使用默认端口,需要传入端口参数。

3. 业务数据的改造,解决并行导致的账号互踢,给不同设备分配不同的账号。

4. 需要拆分测试集,合理安排test suit,那些case是可以并行的,那些测试是需要串行执行的。可以用pytest的标签来分类,也可以用pytest的class name,或者文件名来对test case进行分组。

5. 测试框架使用Appium时,cnpm 安装的appium会有bug没无法使用并行测试,需要使用npm重新安装appium。

       首先是在设置设备的capbility的时候,从环境变量中传入UDID(os.getenv('udid', None)),指定是在那个设备上执行测试用例。

      然后是使用utils.free_port()获取一个未被使用的端口作为连接底层driver的systemPort(官网解释如下:systemPort used to connect to  appium-uiautomator2-server  or  appium-espresso-driver . The default is 8200 in general and selects one port from 8200 to 8299 for  appium-uiautomator2-server , it is 8300 from 8300 to 8399 for  appium-espresso-driver . When you run tests in parallel, you must adjust the port to avoid conflicts. Read  Parallel Testing Setup Guide  for more details.)同样给chromedriverPort一个不冲突的端口号(Numeric port to start Chromedriver on. Note that use of this capability is discouraged as it will cause undefined behavior in case there are multiple webviews present. By default Appium will find a free port.)

可以设置combination filter来控制case跑在那些指定的设备上,当filter设置为index%2 ==1时,case会选择其中一个设备来运行,保证每个case只跑一次:

给对应的设备添加节点Node,# of executors设置为1,表示这个节点上一次自能同时跑一个case。在环境变量里添加这个节点对应的设备的udid:

用Jinkens提供的命令启动这些节点:

修改项目的配置,在Configuration Matrix下面添加test suite,也就是那些test suite需要执行,这里用的是pytest的文件名:

Agents,选择对应的节点:

保存项目,能看到一个矩阵式的表格,第一列是需要运行的测试文件,第一行是运行这些case的设备node:

运行项目,会发现总任务在master上,然后master将任务分配给下面的节点执行:

执行完成之后,能看到每个case只在一个设备上运行一次,这样测试的执行策略就完成了:

执行策略跑通之后,需要开始定义测试的具体的执行命令:

测试用例设计之状态转换法

定义

在遇到有事务流或由于某种条件成立导致状态改变的软件项目时,如何进行测试用例的设计就比较麻烦。其他的各种方法,每个被测对象之间是没有相互的关联或数据流向发生,遇到这样的事务流软件就要考虑用其他方法进行用例的设计了。

以前在讲操作系统原理时,曾经提到过进程的状态转换。我们看以下图形:

技术图片
 

 

当进程从就绪队列中被进程调度算法选中的时候,它就被调进CPU里执行,这个时候进程的状态由就绪状态变换到执行状态;而当该进程执行完毕的时候,是由于所分配的时间片用完,进程调度算法又回到就绪队列里重新提取。当进程执行到一定阶段时,由于发生I/O事件,例如:外部数据的输入或运行的中间数据的输出,这时候CPU必须进行中断处理,那么该进程就由执行状态转变成阻塞状态,等待事件的完成;当事件完成后,进程从阻塞状态就转换成就绪状态,等待进程调度算法的再一次选中。

以上是操作系统中进程的状态迁徙过程。

使用步骤

我们以QQ登录界面为例子,用来讲解状态图法设计测试用例。

(一)通过对QQ登录界面的分析,我们看到有4个输入项:

ip1:输入帐号

ip2:输入密码

ip3:点击“登录”按钮

ip4:点击“关闭”按钮

(二)那么从QQ启动界面开始,进行状态迁徙分析:

第1轮状态图:

技术图片
 

 

第2轮状态图:

技术图片
 

 

第3轮状态图:

技术图片
 

 

(三)从最后的状态图中可以看出QQ登录界面最后的状态有7种,那么从这7种状态中构造出状态类表:

技术图片
 

 

(四)有一些用例没有列出,望大家自己思考,最后所有的测试用例都省略

以上是关于6. Jenkins使用Node调度各种测试用例的主要内容,如果未能解决你的问题,请参考以下文章

量角器:获取[DEP0018]弃用警告和测试运行随机终止

无法在 MAC 上使用 jenkins 在模拟器上运行测试用例

jenkins 中的测试用例

模板+测试工作文档模板+1测试策略&测试计划

jenkins+github+python执行测试用例

有没有办法从jenkins向机器人测试用例发送参数/值?