Robot Framework之---接口测试实战

来源:互联网 发布:淘宝名字大全霸气的 编辑:程序博客网 时间:2024/05/31 19:02

RF框架介绍
Robot Framework 
框架是一个通用的测试框架,一直是由诺西网络(Nokia Siemens Networks Oyj)的人员在维护的。后来诺基亚卖掉了手机业务后,现在更名成诺基亚解决方案网络(Nokia Solutions and Networks)了。现在还是那帮子老外们在维护,已经到 2.9 了,不过 2.9 碰到很多问题,暂时还是用 2.8.7 比较好。

下面介绍一下 RF 的特性:
易于使用,采用表格式语法,统一测试用例格式;
可以使用关键字驱动(keyword-driven)、数据驱动(data-driven)和行为驱动开发 (BDD) 完成;
重用性好,可以利用现有关键字来组合新关键字;
结果报告和日志采用 HTML 格式,易于阅读;
平台和应用无关联性;

模块结构支持使用不同的接口来测试你的应用;
易于扩展,提供了简单 API,用户可以自定义的基于 Python 或者 Java 的测试库;
易于集成,提供了命令行接口和基于 XML 的输出文件;
功能全面,支持WEB测试(Selenium)、Java GUI 测试,启动线程、TelnetSSH 等;
RemoteLibrary 
接口可以支持分布测试和使用其他编程语言实现测试库;
提供tag标签来分类和选择你的案例执行;
内置支持变量variables,支持不同的环境进行测试;

根据我的理解,整理了一个比较形象的Robotframework框架图,如图:


Robot <wbr>Framework之---接口测试实战


Robotframework作为框架平台,上面可以加载各种Library,通过测试套件、资源文件集成起来,然后可以针对被测系统进行不同角度的测试,图中只列了三种Library,实际上还有很多种不同方向的Library,这里只是方便大家理解。


Requests接口自动化测试介绍


主要介绍几种常见的接口如何进行自动化测试,重点是get requestpost request
这部分测试案例可以在这里找到:https://github.com/qitaos/rf-demos/tree/master/RequestsDemo

1.接口测试
接口测试通常是系统之间交互的接口,或者某个系统对外提供的一些接口服务,我之前接触的大部分都是RESTful,还有一些webservice的接口。现在大家也越来越多的关注接口测试了,因为有时候可能界面上的功能还没有实现,我们可以先一步对接口进行验证,提早发现一些和预期不一致的错误。这方面的工具应该也有一些,基于RF的接口测试库我们首推requestsrequestsLibrary

2.requestsLibraryrequests安装
  可以通过pip安装,或者手动安装,下载地址如下,如果是下载安装,先要安装requests,再安装requestsLibrary

  requests的官方下载地址: https://pypi.python.org/pypi/requests
  requestsLibrary
的官方下载地址:https://pypi.python.org/pypi/robotframework-requests/

3. requestsLibrary关键字

requestsLibrary的关键字不多,我常用的就几个。
Create Session: 
创建一个session,连接某个服务器
Create Ntlm Session: 
也是创建一个session,只不过加上了域、用户名、密码用于NTLM认证。
Get Request: 
通过GET方式发起请求。
Post Request: 
通过POST方式发起请求。
Head Request: 
发送一个HEAD请求。
TO Json: 
将文本转换成json对象。

3.4 测试案例
这里的demo我们是用到了flask的网站,做了几种例子,大家了解一下,如果需要更完整的了解,建议看一下RequestsLibrarygithub上的测试案例。

3.4.0 使用demo前的准备
我用了flask来实现了一个demo网站,它可以快速建立起一个网站,只用一些简单的语句。
如果使用pip安装会比较方便,特别是在mac电脑上,为了保证例子能正常运行,大家需要安装四个东东,flaskflask-httpauthflask_restfulpython-simplexml

只需要运行如下命令:

mac

sudo pip install flask
sudo pip install flask-httpauth
sudo pip install flask_restful
sudo pip installpython-simplexml

windows

pip install flask
pip install flask-httpauth
pip install flask_restful
pip install python-simplexml

安装完成之后就可以运行我们的demo-website了,我的书里全部的demo的地址是:
https://github.com/qitaos/rf-demos

具体说明可以看网站上的README,所有的demo都会放到这里,同时书籍出版后也会继续更新,所以你看到githubrf-demos的内容可能会比书上的多。
demo-website
的地址是:https://github.com/qitaos/rf-demos/tree/master/demo-website

下载整个工程之后,进入demo-website目录,
运行命令
python flaskdemo.py
运行成功后会有提示信息

python flaskdemo.py

  1. Running onhttp://127.0.0.1:8000/ (Press CTRL+C to quit)
  2. Restarting with stat
    这里提示我们服务器已经启动,访问http://127.0.0.1:8000/ 或者 http://localhost:8000/ 就可以打开页面了。
    如果有任何出错信息,有可能是前面的测试库没有安装完整。

1get request json
访问http://localhost:8000/users/1 的时候,它会返回一个json:
{“1”: “john”}

Robot <wbr>Framework之---接口测试实战

如果把1换成5,它会返回一个404json:
{
“message”: “NotFound: http://localhost:8000/users/5“,
“status”: 404
}

Robot <wbr>Framework之---接口测试实战

所以这里第一个案例就是来测试这2个接口请求。

首先要先Create Session创建一个连接到服务器的host,然后通过Get Request发起请求,请求的返回是个Request对象${addr},所以在这里的变量是个对象,而对象的属性值的有${addr.status_code}${addr.content},使用了To Json后,就把返回的content格式化成Json串,然后就可以用Dictionary的方法获取其中的值了。脚本见表格

Robot <wbr>Framework之---接口测试实战

2getrequest xml

前面一个例子是接口返回json进行处理的,这个例子是接口返回xml格式内容。访问http://localhost:8000/hello/qitao,会返回一个xml格式的内容:

qitao

 

Robot <wbr>Framework之---接口测试实战

案例比较长,分两个部分说,第一个部分其实还是用json来处理,虽然返回的是xml,但是requestslibrary自动把它处理成json了。所以它的这部分处理其实和前面的案例一样。脚本见表格

Robot <wbr>Framework之---接口测试实战

那么想要返回xml怎么处理呢?这里就要在Requestessay-header里加上一个accept=application/xml,此时返回的就是一个xml格式的内容qitao

 

所以这里用到了XML库的关键字Get Element Text来获取xml节点的文本,使用Get Element获取到一个Element对象${hello},既然是对象,那么它也有属性值${hello.text}。再后面的几行就是用XML库的关键字新增Element,然后取值,这也算是提前准备好来XMLdemo了。

 

这里为什么要做xml的例子呢,其实是因为有一种接口测试就是测试Web Service的,通常Web Service都是返回一个xml格式的内容。这里demo网站没有做Web Service的例子,所以就用这个xml的例子来代替Web Service了。脚本见表格

 

Robot <wbr>Framework之---接口测试实战

运行案例结果如图:

Robot <wbr>Framework之---接口测试实战

3、增加登录态
有些接口是需要用户密码登录后才能访问的,如果直接访问http://localhost:8000/401

会提示要输入用户名密码

Robot <wbr>Framework之---接口测试实战

输入正确的用户名密码ok/python,会得到一个返回的信息
{
“pass”:”Authorized access”
}

但是我们做自动化脚本的时候不能去手动输入的,所以我们可以在Create Session的时候加上用户名密码,就可以直接访问了。

用户名ok,密码python,我们用${auth}创建个List存起来,然后在Create Session时加上${auth}参数,后面的过程就是前面一样了,不需要自己再手动输入用户密码了。脚本见表格

Robot <wbr>Framework之---接口测试实战

运行结果如图

Robot <wbr>Framework之---接口测试实战

4
postrequest
前面几个都是get方式的,这个例子是post方式的。
这里主要是在essay-header加了一项Content-Type=application/x-www-form-urlencoded,这是最常见的post提交数据的方式,另外还有几种我不太常用的,大家可以根据自己的实际情况来使用。

然后我们向 http://localhost:8000/post, 发起请求,并将${data}作为postdata传过去。demo网站对post请求做了个处理,将username的值获取到然后以json格式返回。脚本见表格

Robot <wbr>Framework之---接口测试实战

原创粉丝点击