本文节选自霍格沃兹测试开发学社内部教材
在调试接口用例过程中,如果响应结果和预期结果不一致,则需要检查请求信息。通过代理获取自动化测试中的请求响应信息,对比与正常请求响应的区别,就能够更直观的排查请求错误,相当于编写代码时的 debug 功能。
实战练习
在自动化测试中,不论是 Java 版本还是 Python 版本,均可以通过设置代理来监听自动化测试脚本的请求响应信息。
Python 版本
通过 proxies
参数,监听请求与响应信息。
- import requests
-
- # 1. 定义一个代理的配置信息,分别需要设定http协议与https协议的代理地址。
-
- proxy = {
-
- "http": "http://127.0.0.1:8000",
-
- "https": "http://127.0.0.1:8080"
-
- }
-
-
-
-
- requests.post(url="https://httpbin.ceshiren.com", proxies=proxy, verify=False)
通过 proxies 设定代理信息,代理格式要求为字典类型。默认情况下,verify 是设置为 True 的。将 verify 设置为 False,在发送 HTTPS 请求的时候,Requests 能忽略对 SSL 证书的验证。
Java 版本
- import io.restassured.RestAssured;
-
- import static io.restassured.RestAssured.*;
-
- import static io.restassured.specification.ProxySpecification.host;
-
- import static org.hamcrest.core.IsEqual.equalTo;
-
- public class Requests {
-
- public static void main(String[] args) {
-
- RestAssured.proxy = host("127.0.0.1").withPort(8080);
-
- given().relaxedHTTPSValidation().when().get("https://httpbin.ceshiren.com/get").
-
- then().log().all();
-
- }
-
- }
使用代理工具验证结果
在实际工作中,使用代理工具(参考常用代理工具章节)结合代理配置可以清楚查看每一次的请求信息,实际操作步骤如下:
Python 版本
- import requests
-
- def test_proxy():
-
- # 1. 定义一个代理的配置信息
-
- proxy = {
-
- "http": "http://127.0.0.1:8888",
-
- "https": "http://127.0.0.1:8000"
-
- }
-
-
- # 2. 通过proxies 传递代理配置
-
- requests.post(url="https://httpbin.ceshiren.com/post",
-
- data={'school': "第二次请求"},
-
- verify=False)
Java 版本
- import io.restassured.RestAssured;
-
- import static io.restassured.RestAssured.*;
-
- import static io.restassured.specification.ProxySpecification.host;
-
- public class Requests {
-
- public static void main(String[] args) {
-
- RestAssured.proxy = host("127.0.0.1").withPort(8080);
-
- given().
-
- contentType("application/x-www-form-urlencoded;charset=utf-8").
-
- formParam("school", "第二次请求").relaxedHTTPSValidation().
-
- when().
-
- post("https://httpbin.ceshiren.com/post").
-
- then()
-
- .log().all();
-
- }
-
- }
抓包工具抓包结果如下图所示:
通过以上案例,可以看出将代理配置和代理工具结合使用,可以非常直观看出两次接口请求的差别,从而提高定位接口测试脚本问题的效率。