我现在已经成功地使用Pabot运行了并行机器人框架测试(如果还没有,请检查一下)。目前,我同时运行两个简单的测试,其中包括与两种不同类型的用户进行登录。我使用以下命令从命令行运行测试:
pabot --pabotlib --processes 2 --resourcefile valueset.dat --outputdir c:\pabot-demo\reports\ *.robot
一切顺利:打开浏览器,将登录数据正确提交到表单,显示登录后主页,然后关闭浏览器。问题是,在那之后,我的终端进入某种循环,并且执行似乎在技术上还没有完成:
Robot Framework remote server at 127.0.0.1:8270 started.
2018-10-16 15:58:38.109000 [PID:2144] [0] EXECUTING Suites.LoginAdmin
2018-10-16 15:58:38.109000 [PID:9736] [1] EXECUTING Suites.LoginUser
DevTools listening on ws://127.0.0.1:55688/devtools/browser/9bed6f8e-36c8-40b2-81f5-4622a4933c12
DevTools listening on ws://127.0.0.1:55689/devtools/browser/074fb0f2-5613-4483-9747-5b98eff98dcd
2018-10-16 15:58:53.853000 [PID:2144] [0] still running Suites.LoginAdmin after 15.0 seconds (next ping in 20.0 seconds)
2018-10-16 15:58:53.953000 [PID:9736] [1] still running Suites.LoginUser after 15.0 seconds (next ping in 20.0 seconds)
2018-10-16 15:59:15.693000 [PID:2144] [0] still running Suites.LoginAdmin after 35.0 seconds (next ping in 25.0 seconds)
2018-10-16 15:59:15.809000 [PID:9736] [1] still running Suites.LoginUser after 35.0 seconds (next ping in 25.0 seconds)
2018-10-16 15:59:43.321000 [PID:2144] [0] still running Suites.LoginAdmin after 60.0 seconds (next ping in 30.0 seconds)
2018-10-16 15:59:43.437000 [PID:9736] [1] still running Suites.LoginUser after 60.0 seconds (next ping in 30.0 seconds)
2018-10-16 16:00:16.330000 [PID:2144] [0] still running Suites.LoginAdmin after 90.0 seconds (next ping in 35.0 seconds)
2018-10-16 16:00:16.415000 [PID:9736] [1] still running Suites.LoginUser after 90.0 seconds (next ping in 35.0 seconds)
2018-10-16 16:00:55.144000 [PID:2144] [0] still running Suites.LoginAdmin after 125.0 seconds (next ping in 40.0 seconds)
2018-10-16 16:00:55.212000 [PID:9736] [1] still running Suites.LoginUser after 125.0 seconds (next ping in 40.0 seconds)
2018-10-16 16:01:39.360000 [PID:2144] [0] still running Suites.LoginAdmin after 165.0 seconds (next ping in 45.0 seconds)
2018-10-16 16:01:39.507000 [PID:9736] [1] still running Suites.LoginUser after 165.0 seconds (next ping in 45.0 seconds)
2018-10-16 16:02:29.098000 [PID:2144] [0] still running Suites.LoginAdmin after 210.0 seconds (next ping in 50.0 seconds)
2018-10-16 16:02:29.445000 [PID:9736] [1] still running Suites.LoginUser after 210.0 seconds (next ping in 50.0 seconds)
2018-10-16 16:02:31.716000 [PID:2144] [0] PASSED Suites.LoginAdmin in 212.3 seconds
2018-10-16 16:02:32.300000 [PID:9736] [1] PASSED Suites.LoginUser in 212.5 seconds
Output: c:\pabot-demo\reports\output.xml
Log: c:\pabot-demo\reports\log.html
Report: c:\pabot-demo\reports\report.html
Stopping PabotLib process
Robot Framework remote server at 127.0.0.1:8270 stopped.
PabotLib process stopped
Elapsed time: 3 minutes 54.904 seconds`
每次持续3-4分钟,然后自行停止。 我的测试场景非常简单:
*** Settings ***
Documentation Tests login functionality
Library SeleniumLibrary
Library OperatingSystem
Library DateTime
Library Screenshot
Library pabot.PabotLib
Resource common.robot
Test Setup General Setup
Test Teardown End Scenario
*** Tags ***
Enduser
*** Keywords ***
End Scenario
Run Keyword If Test Failed Take Screenshot 01_LoginEnduserTest_FAILED_ScreenShot.png
Close Browser
General Setup
# CREATING THE DRIVER VARIABLE
Set Global Variable ${DRIVERNAME} Chrome
# CREATING THE SCREENSHOT DIRECTORY
Set Global Variable ${SCREENSHOTPATH} [a path]/target/robotframework-reports/${DRIVERNAME}
Create Directory ${SCREENSHOTPATH}
Set Screenshot Directory ${SCREENSHOTPATH}
# Getting the valueset
${valuesetname}= Acquire Value Set
# Opening the browser
Open Browser [the application's URL] Chrome
Maximize Browser Window
Location Should Contain [part of the application's URL]
*** Test Cases ***
Login
${username} = Get Value From Set username
${password} = Get Value From Set password
Input Text //input[@name='josso_username'] ${username}
Input Text //input[@name='josso_password'] ${password}
Click Element //input[@type='submit']
Wait Until Page Contains Dossier 60
Location Should Be [the application's URL]
Sleep 5s
当然,另一种情况是这种情况的变体。正常执行后,浏览器关闭,我必须等待3至4分钟才能停止ping消息并生成报告,如我们在此处看到的:
在看到潜在的未来发展(例如,在我们目前缺乏资源的不同机器上运行测试)之后,我正在使用valueset.dat文件来获取不同的用户名/密码组合。该文件的内容与我们在Pabot示例中看到的内容非常相似,但无论如何我还是应该包括它:
[Server1]
HOST=(my local IP)
USERNAME=system_admin
PASSWORD=1234
[Server2]
HOST=(my local IP)
USERNAME=system_user
PASSWORD=1234
有什么想法可以让这个漫长的等待消失吗?当我在每个套件中添加更多测试时,是否有可能变得无关紧要?
编辑,我正在使用以下设置:
Python 2.7.14
wxPython 2.8.12.1 ,用于py27的win64,unicode
setuptools 40.2.0 (允许我使用easy_install命令)
机器人框架3.0.4
robotremoteserver 1.1
Selenium2Library 3.0.0
和 Pabot版本0.45 。
此外,我的测试是针对Chrome进行的,因此我使用的是 chromedriver 2.41 。