3

我有一个使用 REST-assured 的测试。在这个测试中,当我将完整的主机和路径传递给 get() 方法时,一切正常,测试通过。但是当我尝试使用 RestAssured.baseURI 和 RestAssured.basePath 就像它在教程的这一部分中显示的那样:http://code.google.com/p/rest-assured/wiki/Usage#Default_values,测试以 Connection 结束重置。下面我粘贴了工作版本和带有不起作用的 baseURI 的版本,以及我得到的错误。请帮忙:>

工作版本:

import com.jayway.restassured.RestAssured;
import org.testng.annotations.DataProvider;
import org.testng.annotations.Test;

import java.util.Iterator;

import static com.jayway.restassured.RestAssured.basic;
import static com.jayway.restassured.RestAssured.given;
import static org.hamcrest.Matchers.containsString;

public class SomeTest {

    @Test(dataProvider = "provideData")
    public void doSomeTest(String someParameter, String someExpectedValue) {

        given().
                auth().basic("login", "pass").
                param("someParameter", someParameter).
        when().
                get("http://some.host/some-base-path/some-path-relevant-in-test").
        then().
                statusCode(200).
                body("some json", containsString(someExpectedValue)).
                log().ifError();
    }

    @DataProvider(name = "provideData")
    public Iterator<Object[]> provideData() {

        //this provides data for test method in irrelevant way
    }

}

导致连接重置的不工作版本:

import com.jayway.restassured.RestAssured;
import org.testng.annotations.DataProvider;
import org.testng.annotations.Test;

import java.util.Iterator;

import static com.jayway.restassured.RestAssured.basic;
import static com.jayway.restassured.RestAssured.given;
import static org.hamcrest.Matchers.containsString;

public class SomeTest {

    @Test(dataProvider = "provideData")
        public void doSomeTest(String someParameter, String someExpectedValue) {

        RestAssured.baseURI = "http://some.host";
        RestAssured.basePath = "/some-base-path";

        given().
                auth().basic("login", "pass").
                param("someParameter", someParameter).
        when().
                get("/some-path-relevant-in-test").
        then().
                statusCode(200).
                body("some json", containsString(someExpectedValue)).
                log().ifError();
    }

    @DataProvider(name = "provideData")
    public Iterator<Object[]> provideData() {

        //this provides data for test method in irrelevant way
    }
}

错误:

mar 19, 2014 10:26:01 AM org.apache.http.impl.client.DefaultRequestDirector tryExecute
INFO: I/O exception (java.net.SocketException) caught when processing request: Connection reset
mar 19, 2014 10:26:01 AM org.apache.http.impl.client.DefaultRequestDirector tryExecute
INFO: Retrying request

我究竟做错了什么?:(

4

2 回答 2

1

您是否在短时间内提出了许多请求?您可以尝试在每次请求后关闭空闲连接和/或为多个请求重用 HTTP 客户端实例

于 2014-03-20T18:55:15.733 回答
0

这似乎是在版本 2.8.1 上修复的 Restassured 中的一个错误。资源泄漏,连接未关闭。请参阅https://github.com/rest-assured/rest-assured/issues/633

于 2016-09-21T12:49:22.733 回答