Модульные тесты Android — IncompatableClassChangeError при запуске MockServer с Robolectric

У меня есть этот тестовый класс...

package com.blah.blah;

import static org.junit.Assert.assertTrue;

import com.squareup.okhttp.mockwebserver.MockWebServer;

import java.io.IOException;

import org.junit.After;
import org.junit.Before;
import org.junit.Test;
import org.junit.runner.RunWith;
import org.robolectric.RobolectricTestRunner;
import org.robolectric.annotation.Config;

@Config(emulateSdk = 18)
@RunWith(RobolectricTestRunner.class)
public class IncompatibleClassChangeErrorTest {

    private MockWebServer server;

    @Before
    public void setup() throws IOException {
        server = new MockWebServer();
        server.play();
    }

    @After
    public void teardown() throws IOException {
        server.shutdown(); // TODO Fix if possible. This throws java.lang.IncompatibleClassChangeError
    }

    @Test
    public void test() {
        assertTrue(true);
    }
}

... и в консолях Eclipse и Android Studio появляется следующий стек исключений...

Exception in thread "pool-2-thread-1" java.lang.IncompatibleClassChangeError: Class java.net.ServerSocket does not implement the requested interface java.io.Closeable
    at com.squareup.okhttp.internal.Util.closeQuietly(Util.java:110)
    at com.squareup.okhttp.mockwebserver.MockWebServer$2.run(MockWebServer.java:249)
    at com.squareup.okhttp.mockwebserver.MockWebServer$4.run(MockWebServer.java:624)
    at java.util.concurrent.ThreadPoolExecutor$Worker.runTask(ThreadPoolExecutor.java:895)
    at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:918)
    at java.lang.Thread.run(Thread.java:695)

...иначе тест пройден. Также запуск теста из командной строки с помощью Gradle просто дает сообщение об успешном завершении.

Если я закомментирую server.shutdown(), все будет в порядке. Хотя, конечно, это не может быть хорошо?


person Myles Bennett    schedule 10.09.2014    source источник


Ответы (1)


Похоже, это следующая проблема, исправленная в версии 1.2.2 https://github.com/square/okhttp/issues/357

Если вы используете более раннюю версию, обновите ее до последней и посмотрите, произойдет ли это.

person Alex Florescu    schedule 18.09.2014
comment
Да, в самом деле. Получил работу с версией 1.6.0 и соответствующей библиотекой okhttp (не okhttp-protocols). - person Myles Bennett; 13.10.2014