• robotframework自动化系列:随机下拉框


    robotframework自动化系列:随机下拉框

    随着项目自动化不断推进,在下拉框定位的时候出现些问题,每次下拉框选择都是相同的下拉选项,如果想每次选择的选项不一样,该如何实现呢,查找了很多资料,没有找到一个好的解决方法....
    最后看到一篇文章,想到可以用随机数尝试一下

    参考 http://lebook.me/book/126586#fid_24191914

    项目中的下拉框源码如图
    ``

    而下拉框定位的方法,如图
    销售类型 [Arguments] ${sale_pattern} #销售类型选择 select from list xpath = .//*[@id='organizationForm']/div/div[1]/div[3]/div/select 租赁 Comment select from list by value organization.sale_pattern 1 Comment ${sale_pattern} evaluate random.randint(1,2) random Comment select from list by value organization.sale_pattern ${sale_pattern}

    销售类型下拉
    这样定位的弊端,如果类型改变每次都需要修改,而且每次运行用例选中的类型是一样的,不能确定其他类型是否正确输入和显示。

    需要实现的思路是:每次运行测试用例,可以根据随机数自动选中其中某个下拉选项,这样对用例执行而言,能够保证用例的健壮性。
    而robotframework的关键字evaluate可以得到一个随机数,修改销售类型的关键字,修改如下:
    随机销售模式 #销售模式随机 ${sale_pattern} evaluate random.randint(1,2) random select from list by value organization.sale_pattern ${sale_pattern}

    如图:
    修改后的销售模式
    但是用例执行后的结果出错了,截图所示
    用例错误截图
    提示信息说明用例中的select from list by value中的值的字符类型错误...
    在robotframework中convert to string实现字符的转换,代码如下
    ${sale_pattern_temp} evaluate random.randint(0,1) random ${sale_pattern} Convert To String ${sale_pattern_temp} Comment select from list by value organization.sale_pattern 2 Comment select from list by value organization.sale_pattern ${sale_pattern} select from list by index organization.sale_pattern ${sale_pattern}
    代码如图
    修改后的代码
    再次运行此用例,终于成功,(o)/~
    截图
    成功
    这样修改后,每次下拉框都会选择不同的选项了,(o)/~

  • 相关阅读:
    vue项目在IE中使用的一些坑(未完待续)
    Vue在IE下显示空白问题
    nginx 解决AJAX 跨域问题。
    node.js+express+jade 国际化
    Angular 2 HTTP Requests with Promise
    Windows x64编译 Qt5.7 Mysql驱动
    mysql [Err] 1215
    VS Code 调试Node.js express网站
    Node.js express 入门示例1
    build qt4.8.5 on centos7 or suse11.1
  • 原文地址:https://www.cnblogs.com/LOVEYU/p/7804449.html
Copyright © 2020-2023  润新知