Robot Framework测试用例并行执行

背景

在实际的测试业务中,我们往往会遇到测试用例执行时间比较长,大量的测试用例串行执行的话,会使的整个测试周期变长,导致不能及时的反馈自动化测试的结果。因此我们会想出几种解决方案,来并行的执行测试用例,加快自动化测试时间。做到能够及时的反馈测试结果。

设计方案

方案一:

测试用例分布式执行,通过策略,将不同的测试用例,分发到不同的测试机上进行执行,然后收集测试结果,合并测试报告。

这里我们以web测试为例:

img_6ef8d429d4322acff8962fbe17c58cea.png
test-arch-robot.png

通过Hub节点中心,将不同的测试请求分发到合适的测试节点中去,实现测试的分布式执行。

方案二:

在同一台测试机上,启动不同的进程,来分别执行不同的测试用例,根据测试机的CPU核数确定启动的进程数,实现真正的并行执行。

这里我们主要用到了开源工具pabot来实现robot测试用例的并行执行。

img_e127f6822b28f9fe224eaf0bda9502f3.jpe
robot_pabot.jpg

样例

执行下面这个简单的用例,了解并行执行过程。

pip install -U robotframework-pabot==0.35
git clone https://github.com/wywincl/example-for-pabot.git
cd example-for-robot && pabot --processes 5 topsuite

输出

ubuntu2@ubuntu2-PowerEdge-R410:~/tmp/example-for-pabot$ pabot --processes 5 topsuite
2017-01-05 15:48:13.683078 [PID:30072] [3] EXECUTING Topsuite.Testsuite2-测试2
2017-01-05 15:48:13.690442 [PID:30075] [4] EXECUTING Topsuite.Testsuite3
2017-01-05 15:48:13.689776 [PID:30073] [1] EXECUTING Topsuite.2Suite.Testsuite5-测试5
2017-01-05 15:48:13.696798 [PID:30079] [0] EXECUTING Topsuite.2Suite.Testsuite4
2017-01-05 15:48:13.978538 [PID:30077] [2] EXECUTING Topsuite.Testsuite1
2017-01-05 15:48:14.079019 [PID:30077] [2] PASSED Topsuite.Testsuite1 in 0.1 seconds
2017-01-05 15:48:14.089794 [PID:30072] [3] PASSED Topsuite.Testsuite2-测试2 in 0.4 seconds
2017-01-05 15:48:14.091765 [PID:30075] [4] PASSED Topsuite.Testsuite3 in 0.4 seconds
2017-01-05 15:48:14.094498 [PID:30073] [1] PASSED Topsuite.2Suite.Testsuite5-测试5 in 0.4 seconds
2017-01-05 15:48:14.098067 [PID:30079] [0] PASSED Topsuite.2Suite.Testsuite4 in 0.4 seconds
Output:  /home/ubuntu2/tmp/example-for-pabot/output.xml
Log:     /home/ubuntu2/tmp/example-for-pabot/log.html
Report:  /home/ubuntu2/tmp/example-for-pabot/report.html
Elapsed time: 0 minutes 0.664 seconds

小结

结合Jenkins+docker技术,我们可以很方便的基于上面的两套方案,打造分布式并行自动化测试集群。

备注

Does not Support Other Unicode Character Like Chinese Character. 中文支持问题已经解决了。

  • 0
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Robot Framework是一种开源的自动化测试框架,可以用于UI自动化测试。在使用Robot Framework进行UI自动化测试时,可以将测试用例分为多个步骤或模块,并且可以使用重试机制来增强自动化的稳定性。 重试机制可以在自动化中的某一个步骤、整条自动化用例,甚至是某个模块全部的自动化用例中应用。这意味着,如果一个步骤或用例在第一次执行时失败,可以通过重试机制再次尝试执行,以提高测试的稳定性。 要使用Robot Framework进行UI自动化测试,可以使用robotframework-pabot这个库。你可以通过在终端上运行以下命令来安装它: ``` pip install robotframework-pabot ``` 安装完成后,你可以使用pabot来执行并行的UI自动化测试,以加快测试执行速度。 在默认情况下,如果一个自动化脚本中的某个点击操作失败,Robot Framework会直接报错,并且该条自动化测试用例会被标记为失败。这种行为有时会降低自动化的稳定性。因此,在编写自动化脚本时,我们可以通过合理的异常处理和重试机制来增强自动化的稳定性,例如在点击失败后,可以通过重试机制再次尝试点击,以确保测试的准确性。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* *2* *3* [Robot Framework Selenium UI自动化测试 --- 进阶篇](https://blog.csdn.net/qq_27534003/article/details/87524779)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_1"}}] [.reference_item style="max-width: 100%"] [ .reference_list ]

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值