在调试接口用例过程中,如果响应结果和预期结果不一致,则需要检查请求信息。通过代理获取自动化测试中的请求响应信息,对比与正常请求响应的区别,就能够更直观的排查请求错误,相当于编写代码时的 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"
}
2. 通过proxies 传递代理配置。
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();
}
}
使用代理工具验证结果
在实际工作中,使用代理工具(参考常用代理工具章节)结合代理配置可以清楚查看每一次的请求信息,实际操作步骤如下:
- 抓包工具设置的端口,与代码的代理地址端口保持一致,如下图所示:
- 如下图所示,在页面发起正常的请求信息,post 请求中,请求数据 key 值为 school,value 值为霍格沃兹测试学社:
- 使用自动化测试脚本发起与第2步同样的请求,只是修改 value 值为第二次请求。
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();
}
}
抓包工具抓包结果如下图所示:
通过以上案例,可以看出将代理配置和代理工具结合使用,可以非常直观看出两次接口请求的差别,从而提高定位接口测试脚本问题的效率。