前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >技术分享 | 接口测试中,请求超时该怎么办?

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

原创
作者头像
Hogwarts_测试
发布2022-08-22 09:49:25
9280
发布2022-08-22 09:49:25
举报

原文链接

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

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

image.png
image.png

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

实战练习

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

<strong>Python 版本</strong>

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

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

JAVA版本

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

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

        given().when().get("https://github.com/").then().log().all();

    }
    @Test
    void timeout3(){

        given().when().get("https://httpbin.ceshiren.com/get").then().statusCode(200).log().all();
    }
}

原创声明:本文系作者授权腾讯云开发者社区发表,未经许可,不得转载。

如有侵权,请联系 cloudcommunity@tencent.com 删除。

原创声明:本文系作者授权腾讯云开发者社区发表,未经许可,不得转载。

如有侵权,请联系 cloudcommunity@tencent.com 删除。

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档