RobotFramework之http接口测试库RequestsLibrary使用介绍(十)

学习目录

接口测试

复习下Http协议规范

接口自动化的几个规范

安装Requestslibrary

通过ride导入Requestslibrary库

在resource文件中创建关键字,实现http的Get方法的功能

在resource文件中创建关键字,实现http的post方法的功能

接口测试

本章正式开始介绍我们在日常工作中使用robotframework用到的一些接口测试、数据库测试等功能。

这节内容主要介绍http协议的接口测试包Requestslibrary的使用方法。

复习下Http协议规范

Http协议是基于TCP协议(三次握手)的7层协议(不了解的可以搜索下网络协议模型),所以在开始使用工具之前我们通过浏览器的开发者工具看下http请求的基本消息格式。

我们以输入百度网站为例,通过打开开发者工具,看下访问百度的http请求。

通过上面几张图可以看到 http请求的地址为https://www.baidu.com, 请求的method为Get,请求的url为/,请求响应的status为200,还包括发送请求的消息头headers信息和响应返回的消息头Headers信息。

做接口测试我们关注的肯定也是上述http请求的内容,通过传入的参数,断言返回的消息响应码/消息体是否满足我们的预期。

接口自动化的几个规范

为了方便用例的维护,我们通常会将变量和关键字做成通用的,提供给他人调用。

  1. http接口用到的访问地址、url,用户名密码等信息放入变量,不直接写在关键字或者用例中
  2. 通过创建自己的resource文件和用户关键字,提供给测试套件引用,两者解耦,使其变成通用关键字

安装Requestslibrary

接下来我们先通过pip命令安装一下包

pip install requests

pip install robotframework-requests

安装好以后,生成如下目录(安装的0.8.1版本)

通过ride导入Requestslibrary库

先创建一个resource文件,在resource文件中导入Requestslibrary库。操作方法如下图所示

查看Requestslibrary库的关键字信息

在resource文件中创建关键字,实现http的Get方法的功能。

我们以网站http://httpbin.org/为例介绍下get请求的访问和响应的断言

1、在上面创建的resource文件的右侧编辑区,创建变量,value为http访问的地址http://httpbin.org

2、在上面创建的resource文件点击右键,创建user keyword,输入name和参数,参数为需要传入的相对url。

然后使用Requestslibrary的两个关键字实现http的get方法,两个关键字是

Create Session和GET On Session

  • Create Session 创建会话,会话名称定义为httpapi(根据个人情况定义),${host}为上面定义的访问地址;此处我们没有配置请求头Headers信息,使用默认的,如有需要可以设置请求头的参数,使用headers=字典的形式传入。

具体的参数示例,大家可以看下关键字的介绍:

  • GET On Session关键字传入url为${url},并将返回的响应赋值给变量${res}

  • 最后断言http的响应码是不是200,同时我们打印下响应的内容
  1. 在测试套件中引用该resource文件

2. 创建用例引用上述关键字,并传入/get的url路径

3.执行测试用例

点击report查看详细的测试报告

在resource文件中创建关键字,实现http的post方法的功能

  1. 执行步骤与上述步骤类似,只是使用了POST On Session的关键字,我们直接上图,不在赘述

Post请求的关键字多定义了一个变量,一般作为post请求的body传入,比如一些登录接口会传入用户名和密码等

2.用例引用该关键字,传入/post的url,测试报告中的执行结果如下图所示

总的代码

Rensource文件:

*** Settings ***
Library RequestsLibrary
*** Variables ***
${host} http://httpbin.org
*** Keywords ***
http的get方法
	[Arguments] ${url}
	Create Session httpapi ${host}
	${res} GET On Session httpapi ${url}
	log ${res.status_code}
	Should Be Equal As Numbers ${res.status_code} 200
	log ${res.content}
http的post方法
	[Arguments] ${url}
	Create Session httpapi ${host}
	${data} Create Dictionary user=123456
	${res} POST On Session httpapi ${url} data=${data}
	log ${res.status_code}
	Should Be Equal As Numbers ${res.status_code} 200
	log ${res.content}

测试套件:

*** Settings ***
Resource 资源文件/userresource.robot
*** Test Cases ***
CASE1
	http的get方法 /get
	http的post方法 /post

共勉: 东汉·班固《汉书·枚乘传》:“泰山之管穿石,单极之绠断干。水非石之钻,索非木之锯,渐靡使之然也。”

-----指水滴不断地滴,可以滴穿石头;

-----比喻坚持不懈,集细微的力量也能成就难能的功劳

  • 4
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值