微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

技术分享 | 接口测试中,请求超时该怎么办?

10a425d1c922b08752f1674276de0d60.jpeg

@H_502_3@

本文节选自霍格沃兹测试开发学社内部教材

A 发送请求,然后等待 B 的响应,同时开始超时计时,如果在超时时间内成功接收到响应,则结束等待和计时。如果到了超时时间还没有接收到响应,则结束等待同时此次通讯失败,这个过程叫做请求超时。在接口自动化测试过程中,也常常会碰到请求超时的场景。

如下图所示,测试用例 2 没有设置超时处理,遇到服务端阻塞,测试用例 2 一直处于等待的状态,后面的测试用例都不执行:

ba795399d71262d41809d3a135696832.jpeg

如下图所示,如果测试用例 2 设置了 3s 的超时时间,遇到服务端阻塞,测试用例 2 在 3s 之后则抛出异常,测试用例 3 正常执行:

21c29022c66c4981e68f7ae83884186d.jpeg

实战练习@H_502_3@

3c1d3b24b374b7c4eb74763b72f7cc18.jpeg

编写三条测试用例,在 test_two 测试用例中设置超时时间为 3 秒,超过 3s 还没有得到响应的话则抛出异常,然后正常执行后面的测试用例。

@H_502_3@Python 版本 @H_502_3@@H_502_3@@H_502_3@

Python 可以在调用请求方法时传入 timeout 参数控制超时时间。

import requests@H_502_3@class TestReq:@H_502_3@ def test_one(self):@H_502_3@ r = requests.post("https://httpbin.ceshiren.com/post")@H_502_3@ assert r.status_code == 200@H_502_3@ def test_two(self):@H_502_3@ # 通过timeout 参数设置超时时间,设置超时时间为0.1s,模拟超时场景@H_502_3@ r = requests.post("https://github.com/post", timeout=0.1)@H_502_3@ assert r.status_code == 200@H_502_3@ def test_three(self):@H_502_3@ r = requests.post("https://httpbin.ceshiren.com/post")@H_502_3@ assert r.status_code == 200

Java 版本 @H_502_3@@H_502_3@@H_502_3@

Java 需要通过添加 RestAssured 的配置信息来处理超时的请求。通过 setparam() 设置超时时间,第一个参数为连接的类型,第二个参数为超时的最大时长,单位是 3000 毫秒。

import io.restassured.RestAssured;@H_502_3@import io.restassured.config.HttpClientConfig;@H_502_3@import io.restassured.config.RestAssuredConfig;@H_502_3@import org.junit.jupiter.api.Test;@H_502_3@import static io.restassured.RestAssured.given;@H_502_3@public class ReqTimeoutTest@H_502_3@{@H_502_3@ @Test@H_502_3@ void timeout1(){@H_502_3@ given().@H_502_3@ when().get("https://httpbin.ceshiren.com/get").then().statusCode(200).log().all();@H_502_3@ }@H_502_3@ @Test@H_502_3@ void timeout2(){@H_502_3@ RestAssured.config=RestAssuredConfig.config().httpClient(HttpClientConfig.httpClientConfig().@H_502_3@ setParam("http.connection.timeout",3000).@H_502_3@ setParam("http.socket.timeout",3000).@H_502_3@ setParam("http.connection-manager.timeout",3000));@H_502_3@@H_502_3@ given().when().get("https://github.com/").then().log().all();@H_502_3@@H_502_3@ }@H_502_3@ @Test@H_502_3@ void timeout3(){@H_502_3@@H_502_3@ given().when().get("https://httpbin.ceshiren.com/get").then().statusCode(200).log().all();@H_502_3@ }@H_502_3@}

@H_502_3@

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 [email protected] 举报,一经查实,本站将立刻删除。

相关推荐