Python 如果关键字未失败,则在固定时间内重复执行关键字而不会失败

Python 如果关键字未失败,则在固定时间内重复执行关键字而不会失败,python,robotframework,ping,Python,Robotframework,Ping,在我当前的项目中,我需要检查一个相当复杂的嵌入式系统的以太网连接的稳定性。我们正在使用Robot框架来执行我们的测试用例。现在我想在一段固定的时间内ping这个设备,并编写了一个这样的测试用例 Ping Device [Timeout] 1 hour FOR ${i} IN RANGE 9999999 Run Keyword And Continue On Failure Ping Host 192.168.1.100 END 测试应运行1小

在我当前的项目中,我需要检查一个相当复杂的嵌入式系统的以太网连接的稳定性。我们正在使用Robot框架来执行我们的测试用例。现在我想在一段固定的时间内ping这个设备,并编写了一个这样的测试用例

Ping Device
    [Timeout]  1 hour
    FOR   ${i}  IN RANGE  9999999
      Run Keyword And Continue On Failure   Ping Host  192.168.1.100
    END
测试应运行1小时,如果至少有一个ping失败,则测试应失败。尽管如此,它不应该中止以查看ping失败的情况有多少。不幸的是,由于超时,测试也失败了,这似乎是Robot框架中一种理智和期望的行为,不应该像我那样被滥用


如何,我仍然可以重复执行一个关键字整整一个小时,并且仅在关键字至少失败一次时才失败?

要在一定时间内运行关键字,您应该使用。请注意,它将生成大量日志,因此我建议查看用户指南中的章节

现在,如果一次迭代失败,那么要使测试失败,我建议使用in-a-user关键字,它将任何失败存储在一个测试变量中,您可以使用该变量使测试用例总体失败

下面是一个快乐和不快乐案例的示例,每个关键字运行5秒钟

*** Test Cases ***
Test OK
    Set Test Variable    ${OVERALL RESULT}    True
    Repeat Keyword    5 sec    Run Keyword And Store Failure   Sleep    1 sec    reason=test
    Run Keyword If    ${OVERALL RESULT} == False    Fail    over all fail
    
Test NOK
    Set Test Variable    ${OVERALL RESULT}    True
    Repeat Keyword    5 sec    Run Keyword And Store Failure   Fail    test
    Run Keyword If    ${OVERALL RESULT} == False    Fail    over all fail
    
Test With Random Failures In It
    Set Test Variable    ${OVERALL RESULT}    True
    Repeat Keyword    5 sec    Run Keyword And Store Failure   Fail Randomly
    Run Keyword If    ${OVERALL RESULT} == False    Fail    over all fail
    
*** Keyword ***
Run Keyword And Store Failure
    [arguments]    ${keyword}    @{args}
    ${status}=    Run Keyword And Return Status    ${keyword}    @{args}
    Run Keyword If    ${status} == False    Set Test Variable    ${OVERALL RESULT}    False

Fail Randomly
    ${numbers}=    Evaluate    random.sample(range(1, 200), 4)    random
    Run Keyword If    ${numbers}[0]%2 != 0    Fail     fail  randomly
    Sleep    1 sec     reason=reduce log lines

要在一定时间内运行关键字,应使用。请注意,它将生成大量日志,因此我建议查看用户指南中的章节

现在,如果一次迭代失败,那么要使测试失败,我建议使用in-a-user关键字,它将任何失败存储在一个测试变量中,您可以使用该变量使测试用例总体失败

下面是一个快乐和不快乐案例的示例,每个关键字运行5秒钟

*** Test Cases ***
Test OK
    Set Test Variable    ${OVERALL RESULT}    True
    Repeat Keyword    5 sec    Run Keyword And Store Failure   Sleep    1 sec    reason=test
    Run Keyword If    ${OVERALL RESULT} == False    Fail    over all fail
    
Test NOK
    Set Test Variable    ${OVERALL RESULT}    True
    Repeat Keyword    5 sec    Run Keyword And Store Failure   Fail    test
    Run Keyword If    ${OVERALL RESULT} == False    Fail    over all fail
    
Test With Random Failures In It
    Set Test Variable    ${OVERALL RESULT}    True
    Repeat Keyword    5 sec    Run Keyword And Store Failure   Fail Randomly
    Run Keyword If    ${OVERALL RESULT} == False    Fail    over all fail
    
*** Keyword ***
Run Keyword And Store Failure
    [arguments]    ${keyword}    @{args}
    ${status}=    Run Keyword And Return Status    ${keyword}    @{args}
    Run Keyword If    ${status} == False    Set Test Variable    ${OVERALL RESULT}    False

Fail Randomly
    ${numbers}=    Evaluate    random.sample(range(1, 200), 4)    random
    Run Keyword If    ${numbers}[0]%2 != 0    Fail     fail  randomly
    Sleep    1 sec     reason=reduce log lines

非常感谢您的快速回复。消化你的答案需要一些时间。我会看看我是否能利用它。@Aleph0如果你需要更多的澄清,请告诉我。不,到目前为止,我对你的回答很满意。我会看看如何在生产中使用它。非常感谢您的快速回复。消化你的答案需要一些时间。我会看看我是否能利用它。@Aleph0如果你需要更多的澄清,请告诉我。不,到目前为止,我对你的回答很满意。我会看看如何在生产中使用它。