Pabot-关闭浏览器后,测试执行继续

时间:2018-10-16 14:43:03

标签: python windows-10 automated-tests robotframework

我现在已经成功地使用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消息并生成报告,如我们在此处看到的:

Robotframework report screenshot

在看到潜在的未来发展(例如,在我们目前缺乏资源的不同机器上运行测试)之后,我正在使用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

0 个答案:

没有答案
相关问题