尝试用MocWebSerevr测试时出现错误

时间:2018-10-17 22:10:29

标签: android unit-testing mockwebserver

任何人都知道错误是什么意思吗?或者也许错过了什么?

正尝试从此sample开始,

添加了依赖性:testImplementation 'com.squareup.okhttp3:mockwebserver:3.11.0'

代码刚刚在AndroidStudio的示例单元测试中添加了@Test findMessage_receivesAScriptedResponseFromMockBackend

    public class ExampleUnitTest {
        @Test
        public void addition_isCorrect() {
            assertEquals(4, 2 + 2);
        }

    ///
    @Rule
    public MockWebServer mockBackend = new MockWebServer();

    private MessagesApi mockApi() {
        return new MessagesApi.Builder()
                .baseUrl(mockBackend.url("/").toString())
                .build();
    }

    @Test
    public void builder_returnsInstance() {
        final MessagesApi messagesApi = new MessagesApi.Builder()
                .baseUrl("http://localhost:8888")
                .build();

        assertNotNull(messagesApi);
    }

@Test
public void findMessage_receivesAScriptedResponseFromMockBackend() throws IOException {
    mockBackend.enqueue(
            new MockResponse()
                    .setBody("{\"text\":\"hello!\"}")
                    .setResponseCode(200)
                    .addHeader("Content-Type", "application/json;charset=utf-8")
    );

    final Response<Message> response = mockApi().findMessage("123").execute();

    assertTrue((response.code()) == (200));
    assertTrue((response.headers().get("Content-Type")).contains("application/json"));

    final ResponseBody rawResponseBody = response.raw().body();
    assertTrue((rawResponseBody.contentType().type()).equals("application"));
    assertTrue((rawResponseBody.contentType().subtype()).equals("json"));
}

public class Message {

    public String text;
}

public interface MessagesApi {

    @GET("/message")
    Call<Message> findMessage(@Query("query") String keyword);


    /** Convenient builder for MessagesApi */
    class Builder {
        private String baseUrl;

        public Builder() {}

        public Builder baseUrl(String baseUrl) {
            this.baseUrl = baseUrl;

            return this;
        }

        public MessagesApi build() {
            return new Retrofit.Builder()
                    .client(new OkHttpClient.Builder().build())
                    .addConverterFactory(GsonConverterFactory.create())
                    .baseUrl(baseUrl)
                    .build()
                    .create(MessagesApi.class);
        }
    }
}
}

运行测试时显示错误:

Oct 17, 2018 5:58:57 PM okhttp3.mockwebserver.MockWebServer$2 execute
INFO: MockWebServer[60271] starting to accept connections
Oct 17, 2018 5:58:57 PM okhttp3.mockwebserver.MockWebServer$2 acceptConnections
INFO: MockWebServer[60271] done accepting connections: Socket closed
Oct 17, 2018 5:58:57 PM okhttp3.mockwebserver.MockWebServer$2 execute
INFO: MockWebServer[60272] starting to accept connections
Exception in thread "MockWebServer" java.lang.NoSuchFieldError: H2_PRIOR_KNOWLEDGE
at okhttp3.mockwebserver.MockWebServer$3.processConnection(MockWebServer.java:487)
at okhttp3.mockwebserver.MockWebServer$3.execute(MockWebServer.java:442)
at okhttp3.internal.NamedRunnable.run(NamedRunnable.java:32)
at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1142)
at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:617)
at java.lang.Thread.run(Thread.java:745)
Oct 17, 2018 5:59:07 PM okhttp3.mockwebserver.MockWebServer$2 acceptConnections
INFO: MockWebServer[60272] done accepting connections: Socket closed

java.net.SocketTimeoutException: timeout

2 个答案:

答案 0 :(得分:2)

答案 1 :(得分:0)

如果有人遇到相同的问题,MockWebServer来自OKHttp的相同依赖项,因此他们都需要具有相同的依赖项版本。

因此,此消息可能是因为MockWebServer找不到OkHttp库中定义的属性。就我而言,后者的版本较低,使它们的版本相等就解决了问题。