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

2017-08-13  本文已影响1909人  CC先生之简书

前情介绍:
写上一个练习的时候去搜索了一下PYPI上面RF相关的资源,结果一不小心就推开了世界的新大门,放张图让你们感受下:

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'

版本号是你自己定义的,刚开头,低调一点是对的。如果想装一下呢,从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_ = VERSION


class MyRequestsLibrary(RequestsKeywords):
    """ RequestsLibrary is a HTTP client keyword library that uses
    the requests module


        Examples:
        | Create Session | google | http://www.google.com |
        | Create Session | github  | http://github.com/api/v2/json |
        | ${resp} | Get  google  |  / |
        | Should Be Equal As Strings |  ${resp.status_code} | 200 |
        | ${resp} | Get  github  | /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 = 0

  def 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_redirects

        response = 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),否则导入自定义库时会出错。

import.png

CC先生说:自定义测试库也适合在其它大神写的库上做一定的修改来完成。依据官网的写法,刚做的这个小实验是属于静态自定义测试库,还有动态传入参数的方法,比如上一个练习中的Sikuli库的写法则是动态的,有机会继续研究研究。


上一篇下一篇

猜你喜欢

热点阅读