robot接口自动化用例编写

如何手写robot自动化用例,网上虽然有一大堆教程,但都是关于ride的,对于如何从脚本角度来写,一直零零散散,语焉不详,本文以互联网最常见的API接口自动化为例,给出方向性指引,文字不多,足够你理解,想要深入,请依循文中的文字,再去百度,慢慢体会,逐步精深。

为开江等地区用户提供了全套网页设计制作服务,及开江网站建设行业解决方案。主营业务为网站建设、网站设计、开江网站设计,以传统方式定制建设网站,并提供域名空间备案等一条龙服务,秉承以专业、用心的态度为用户提供真诚的服务。我们深信只要达到每一位用户的要求,就会得到认可,从而选择与我们长期合作。这样,我们也可以走得更远!

用例编写前提:已经部署好了robot/python环境

第一个http接口

*** Settings ***
Library  Collections
Library  Process
Library  RequestsLibrary

*** Variables ***
${DOMAIN}       http://10.xx.xx.xx:8091
${URI}          /test/backend/xxxxlogin
${HEADER}      {"Content-Type":"application/json"}
${USER}        {"accountType":"1", "phonenumStr":"iamusername", "password":"iampassword"}
${LIST_ANIMALS}    ["cat", "dog"]

*** Test Cases ***
my first http test case
    create session  myhttp          ${DOMAIN}
    ${uri}          set variable    ${URI}
    # headers一定要转成 json,不然data传不过去   
    ${header}       to json         ${HEADER}
    ${postdata}     to json         ${DATA}
    ${resp}         post request    myhttp    uri=${uri}      data=${postdata}       headers=${header}

    # 校验 http的状态 
    should be equal as integers  200    ${resp.status_code}
    # 打印 调测信息
    #log     ${resp.content}
    #log     ${json}
    #log     ${json[0]}
    #log     ${json[1]["id"]}

    ${json}   to json     ${resp.content}
    # 校验返回数据的关键值
    should be equal as strings   2.0   ${json[1]["jsonrpc"]}

多步操作

所有的返回值都是字符串类型,转成json后就可以像字典型一样随意取用了

    ${json}   to json     ${resp.content}

把取到值当成下一次调用的入参

建议每个testcase只测试一个功能,接口测试阶段,不要构造过于复杂的场景(用例代码超过一屏将被视为复杂,需要拆分)

结果校验

请求http获得的返回都是字符串类型,解析成json才可以自由取用值
提供多种校验函数如下:

should be equal as integers    
should be equal as numbers  
should be equal as strings
should be true
should be empty
should contain  
should contain any
# not 也支持 
should not be equal as integers    
should not be equal as numbers  
should not be equal as strings
should not be true
should not be empty
should not contain  
should not contain any

数据驱动

robot宣称支持数据驱动,支持按照template从表格读数据来跑用例,但是问题是,如果要对数据表格里的case做拣选和拆分就会无力了,所以,数据驱动适合比较大规模的协议测试,而对于有细力度的统计case的需求是不好用的,我们的建议是用测试数据分散在testcase里,保持case的独立性和灵活性,如果确实有大量的手工操作的话,提供小工具自动创建testcase。

数据驱动即为定义好流程(Template),然后就可以按照参数罗列形成用例了,每一条数据都会独立执行

*** Test Cases ***
Invalid Username
    [Tags]    Iteration-3    Smoke
    [Template]  Login with invalid credentials should fail
    invalidname      qwe123
    091931          invalidpassword

*** Test Cases ***
Login Success
    [Tags]    Iteration-3    Smoke  core
    [Template]  Login success
    068970          qwe123
    052255          qwe123

前置条件(可选)

一个用例文件中包含很多testcase,我想统一加些动作该怎么办?框架提供两个方法,如果是前置条件(每个用例开始前执行)就用Set up,在setting里编写你的动作即可,如果动作很复杂,可以做成关键字调用即可,就像下面一样:


    *** Settings ***
    Test Setup      Get config

    *** Keywords ***
    Get config
            log     正在初始化...
            set suite variable  ${config}       {"env":"uat", "user":"haha"}

清理动作(可选)

如果是后置条件(每个testcase结束后调用),就用Tear down,样例如下:


*** Settings ***
Test Teardown   Do clean

*** Keywords ***
Do clean
    log     正在清理...

关键字驱动

框架提供自定义的关键字方案,只需要在Keywords下面书写你的逻辑动作即可,关键字可以是英文,也可以是中文,顶格写,不限制空格和特殊字符,你可以像书写自然语言一样写用例代码啦

*** Keywords ***
My first keywords
    log     hello keywords

我的第一个关键字
    log     你好, 我的关键字

新闻名称:robot接口自动化用例编写
本文路径:http://csdahua.cn/article/gscjgd.html
扫二维码与项目经理沟通

我们在微信上24小时期待你的声音

解答本文疑问/技术咨询/运营咨询/技术建议/互联网交流