测试自动化顾问 2020-06-12
httprunner 2.x版本最大的改进就是分层机制了,1.x的版本是线性设计的,每个用例都是独立的。
一个用例里面涉及到流程性的,我们测试修改个人信息是否修改成功,在yaml文件里面需写3个步骤:登录-修改个人信息-查询个人信息。
这样3个测试步骤,每个测试步骤写的test下。但是下个测试用例,重新写个yaml文件也需要遇到登录的话,这样登录的步骤就会重复去写,所以维护起来不方便。
httprunner 2.x版本开始引入分层机制,可以定义公共的方法,在用例里面直接引入步骤,这样登录方法我们只需写一次
在自动化测试领域,自动化测试用例的可维护性是极其重要的因素,直接关系到自动化测试能否持续有效地在项目中开展。
概括来说,测试用例分层机制的核心是将接口定义、测试步骤、测试用例、测试场景进行分离,单独进行描述和维护,从而尽可能地减少自动化测试用例的维护成本。
逻辑关系图如下所示:
同时,强调如下几点核心概念:
如果对于上述第三点感觉难以理解,不妨看下上图中的示例:
理解了测试用例分层模型,接下来我们再来看下在分层模型下,接口、测试用例、测试用例集的描述形式。
为了更好地对接口描述进行管理,推荐使用独立的文件对接口描述进行存储,即每个文件对应一个接口描述。
接口定义描述的主要内容包括:name、variables、request、base_url、validate 等,形式如下:
# api/get_header.yml name: get headers base_url: http://httpbin.org variables: expected_status_code: 200 request: url: /headers method: GET validate: - eq: ["status_code", $expected_status_code] - eq: [content.headers.Host, "httpbin.org"]
其中,name 和 request 部分是必须的,request 中的描述形式与 requests.request 完全相同。
另外,API 描述需要尽量保持完整,做到可以单独运行。如果在接口描述中存在变量引用的情况,可在 variables 中对参数进行定义。
通过这种方式,可以很好地实现单个接口的调试。
(venv_hrun) D:\soft\venu_hrun>hrun api/get_header.yml INFO HttpRunner version: 2.5.7 INFO Start to run testcase: get headers get headers INFO GET http://httpbin.org/headers INFO status_code: 200, response_time(ms): 594.7 ms, response_length: 225 bytes . ---------------------------------------------------------------------- Ran 1 test in 0.597s OK INFO Start to render Html report ... INFO Generated Html report: D:\soft\venu_hrun\reports\20200612T144524.746202.html OK
接下来把登录写到api,测试用例去引用登录api,在项目根目录新建一个api目录,写login.yml文件内容
# 上海-悠悠,httprunner QQ交流群:1121184576 name: login first base_url: http://49.235.92.12:6009 variables: user: test password: 123456 request: url: http://49.235.92.12:6009/api/v1/login/ method: POST headers: Content-Type: application/json User-Agent: python-requests/2.18.4 json: username: test password: 123456 validate: - eq: [status_code, 200] - eq: [headers.Content-Type, application/json] - eq: [content.msg, login success!] - eq: [content.code, 0]
我们要保证单个接口是可以执行的
hrun api/login.yml
运行结果
(venv_hrun) D:\soft\venu_hrun>hrun api/login.yml INFO HttpRunner version: 2.5.7 INFO Start to run testcase: login first login first INFO POST http://49.235.92.12:6009/api/v1/login/ INFO status_code: 200, response_time(ms): 179.66 ms, response_length: 109 bytes . ---------------------------------------------------------------------- Ran 1 test in 0.183s OK INFO Start to render Html report ... INFO Generated Html report: D:\soft\venu_hrun\reports\20200612T151122.418051.html
接下来把获取个人信息的接口也写到api层,get_userinfo.yml内容
token 这个参数是可变的,每次登录都会生成一个新的值,这里为了调试的通,可以先登录后,把token复制过来
# 上海-悠悠,httprunner QQ交流群:1121184576 name: get user info case1 base_url: http://127.0.0.1:8000 variables: token: 1c5ef1856edec117ac989eb8def4abbaae28673e request: url: http://127.0.0.1:8000/api/v1/userinfo/ method: GET headers: Content-Type: application/json User-Agent: python-requests/2.18.4 Authorization: Token $token # 引用token
运行后结果
(venv_hrun) D:\soft\venu_hrun>hrun api/get_userinfo.yml INFO HttpRunner version: 2.5.7 INFO Start to run testcase: get user info case1 get user info case1 INFO GET http://127.0.0.1:8000/api/v1/userinfo/ INFO status_code: 200, response_time(ms): 209.11 ms, response_length: 126 bytes . ---------------------------------------------------------------------- Ran 1 test in 0.211s OK INFO Start to render Html report ... INFO Generated Html report: D:\soft\venu_hrun\reports\20200612T151456.300635.html
用例层在项目根目录下新建一个case目录,专注测试用例的流程,如测试用例流程:登录-获取个人信息
整体设计思路:
# 上海-悠悠,httprunner QQ交流群:1121184576 - config: name: "test userinfo" - test: name: login-setup api: api/login.yml extract: - get_token: content.token validate: - eq: ["status_code", 200] - len_eq: ["content.token", 40] - test: name: get user info case1 api: api/get_userinfo.yml variables: token: $get_token validate: - eq: [status_code, 200] - eq: [headers.Content-Type, application/json] - eq: [content.data.0.age, 24] - eq: [content.data.0.name, test] - eq: [content.data.0.mail, ]
运行结果
(venv_hrun) D:\soft\venu_hrun>hrun case INFO HttpRunner version: 2.5.7 INFO Start to run testcase: test userinfo login-setup INFO POST http://49.235.92.12:6009/api/v1/login/ INFO status_code: 200, response_time(ms): 165.57 ms, response_length: 109 bytes . get user info case1 INFO GET http://127.0.0.1:8000/api/v1/userinfo/ INFO status_code: 200, response_time(ms): 187.49 ms, response_length: 126 bytes . ---------------------------------------------------------------------- Ran 2 tests in 0.360s OK INFO Start to render Html report ... INFO Generated Html report: D:\soft\venu_hrun\reports\20200612T151840.103147.html
推荐的方式汇总如下:
目录结构如下所示:
tests ├── .env ├── data │ ├── app_version.csv │ └── account.csv ├── api │ ├── create_user.yml │ ├── get_headers.yml │ ├── get_userinfo.yml │ └── login.yml ├── debugtalk.py ├── testcases │ ├── test_userinfo.yml │ ├── deps │ │ └── check_and_create.yml │ └── setup.yml └── testsuites ├── create_users.yml └── create_users_with_parameters.yml
基于之前生成的json、yaml文件,通过命令行终端cd到用例所在目录,执行hrun 用例名称即可。执行完测试用例会在当前目录生成一个report文件夹,里面会有一个按时间戳生成的html格式报告文件