robotframework-自动化测试-实例14(如何自定义接口测试库)

前情介绍:
写上一个练习的时候去搜索了一下PYPI上面RF相关的资源,结果一不小心就推开了世界的新大门,放张图让你们感受下:
robotframework-自动化测试-实例14(如何自定义接口测试库)
文章图片
RFS.png 也就是说,只要你想用的,想得到的库在上面几乎都可以找到对应的测试库.
问题来了,如果下载的各种测试库,因为各种原因总是不能完美的实现你想要的测试功能怎么办呢?现在来学习一下怎么自定义一个RFS库吧!
比如我们想新建一个Requests相关做接口的测试库。
1 . 首先给自定义库起名,如MyRequestsLibrary。在python安装目录下的 ..\Lib\site-packages 建立文件夹 MyRequestsLibrary
2 . 在MyRequestsLibrary文件夹中新建1个version.py文件,用于描述自定义测试库的版本信息。代码如下:

''' Created on 2017/08/13 Author: by cc sensei ''' VERSION = '0.0.1'

【robotframework-自动化测试-实例14(如何自定义接口测试库)】版本号是你自己定义的,刚开头,低调一点是对的。如果想装一下呢,从10.0.0开始也没什么不可以。
  1. 在MyRequestsLibrary文件夹中新建1个 _init_.py ,用于定义自定义库的相关信息。和需要用到的keywords调用继承和声明。代码如下:
''' Created on 2017/08/13 Author: by cc sensei ''' from .RequestsKeywords import RequestsKeywords from .version import VERSION_version_ = VERSIONclass MyRequestsLibrary(RequestsKeywords): """ RequestsLibrary is a HTTP client keyword library that uses the requests moduleExamples: | Create Session | google | http://www.google.com | | Create Session | github| http://github.com/api/v2/json | | ${resp} | Getgoogle|/ | | Should Be Equal As Strings |${resp.status_code} | 200 | | ${resp} | Getgithub| /user/search/bulkan | | Should Be Equal As Strings|${resp.status_code} | 200 | | ${jsondata}| To Json |${resp.content} | | Dictionary Should Contain Value | ${jsondata['users'][0]} | Bulkan Savun Evcimen |""" ROBOT_LIBRARY_SCOPE = 'GLOBAL'

  1. 在MyRequestsLibrary文件夹中新建1个RequestsKeywords类(用于完成想封装的各项功能)。比如为:RequestsKeywords.py。部分代码如下:
class RequestsKeywords(object): def __init__(self): self._cache = robot.utils.ConnectionCache('No sessions created') self.builtin = BuiltIn() self.debug = 0def get_request( self, alias, uri, headers=None, json=None, params=None, allow_redirects=None, timeout=None): """ Send a GET request on the session object found using the given `alias```alias`` that will be used to identify the Session object in the cache``uri`` to send the GET request to``params`` url parameters to append to the uri``headers`` a dictionary of headers to use with the request``json`` json data to send in the body of the :class:`Request`.``allow_redirects`` Boolean. Set to True if POST/PUT/DELETE redirect following is allowed.``timeout`` connection timeout """ session = self._cache.switch(alias) redir = True if allow_redirects is None else allow_redirectsresponse = self._get_request( session, uri, params, headers, json, redir, timeout)logger.info( 'Get Request using : alias=%s, uri=%s, headers=%s json=%s' % (alias, uri, headers, json))return response

keywords类中使用的其实就是你想在这个库里所使用的关键字所对应的代码。里面的代码都可以自行去实现。在此不一一解释。
启动ride程序在setting部分添加library库信息,添加库名为MyRequestsLibrary,即可成功导入自定义库。这时候也可以拷给其它人随意使用了。
注意:库文件夹名称一定要和类名称相同(MyRequestsLibrary),否则导入自定义库时会出错。
robotframework-自动化测试-实例14(如何自定义接口测试库)
文章图片
import.png
CC先生说:自定义测试库也适合在其它大神写的库上做一定的修改来完成。依据官网的写法,刚做的这个小实验是属于静态自定义测试库,还有动态传入参数的方法,比如上一个练习中的Sikuli库的写法则是动态的,有机会继续研究研究。
  • 练习环境配置
  • 实例1(UI自动化-百度搜索)
  • 实例2(有效登录)
  • 实例3(无效登录)
  • 实例4 ( Appium )
  • 实例5 ( 连接mysql数据库)
  • 实例6 ( GET/POST请求)
  • 实例7(接口API测试)
  • 实例8 (数据驱动)
  • 实例9 (行为驱动)
  • 实例10(接口加密)
  • 实例11(Jenkins集成)
  • 实例12(C/S架构-AutoIt)
  • 实例13 (Sikuli-所见即所得)
  • Appium Error总结
  • robotframework Error总结

    推荐阅读