Ошибка сборки Android + Powermock + Mockito + Maven с ClassNotFoundException

Я столкнулся со странной проблемой сборки с powermock и mockito с использованием maven. Я могу отлично запустить тесты с ecplise (без использования maven). Но когда я пытаюсь запустить тест с помощью maven из cli или на сервере сборки, я получаю следующее исключение:

Ошибочные тесты: Механизм тестирования: java.lang.ClassNotFoundException: org.mockito.internal.progres s.ThreadSafeMockingProgress

Мой модульный тест выглядит так:

import static org.hamcrest.CoreMatchers.is;
import static org.hamcrest.CoreMatchers.notNullValue;
import static org.junit.Assert.assertThat;
import static org.mockito.Matchers.anyString;
import static org.mockito.Mockito.when;

import java.io.IOException;

import org.junit.Before;
import org.junit.Test;
import org.junit.runner.RunWith;
import org.mockito.Mock;
import org.mockito.invocation.InvocationOnMock;
import org.mockito.stubbing.Answer;
import org.powermock.api.mockito.PowerMockito;
import org.powermock.core.classloader.annotations.PrepareForTest;
import org.powermock.modules.junit4.PowerMockRunner;

import android.util.Log;

import com.generic_io.concurrent.ResultReceiverCallableFactory;


@RunWith(PowerMockRunner.class)
@PrepareForTest({
    Log.class
})
public class TestPowerMockTest
{

    @Mock
    ResultReceiverCallableFactory callableFactory;

    @Before
    public void setUp() throws IOException
    {
        mockLogger();
    }


    private void mockLogger()
    {
        PowerMockito.mockStatic(Log.class);
        when(Log.d(anyString(), anyString())).thenAnswer(new Answer<Integer>()
        {

            @Override
            public Integer answer(final InvocationOnMock invocation) throws Throwable
            {
                final String tag = (String) invocation.getArguments()[0];
                final String msg = (String) invocation.getArguments()[1];
                System.out.println("[" + tag + "] " + msg);
                return 0;
            }
        });

    }


    @Test
    public void testPreconditions()
    {
        assertThat("ResultReceiverCallableFactory is null", callableFactory, is(notNullValue()));
    }
}

Мой pom.xml выглядит так:

<dependencies>
    <dependency>
      <groupId>com.google.android</groupId>
      <artifactId>android</artifactId>
      <version>2.2.1</version>
      <scope>provided</scope>
    </dependency>

    <dependency>
      <groupId>com.generic_io</groupId>
      <artifactId>generic_io</artifactId>
      <version>1.0-SNAPSHOT</version>
      <type>jar</type>
      <scope>provided</scope>
    </dependency>

    <dependency>
      <groupId>com.pivotallabs</groupId>
      <artifactId>robolectric</artifactId>
      <version>1.0-RC1</version>
      <scope>test</scope>
    </dependency>

    <dependency>
      <groupId>junit</groupId>
      <artifactId>junit</artifactId>
      <version>4.8.2</version>
      <type>jar</type>
      <scope>test</scope>
    </dependency>

    <dependency>
      <groupId>org.powermock</groupId>
      <artifactId>powermock-api-mockito</artifactId>
      <version>1.4.9</version>
      <type>jar</type>
       <scope>test</scope>
    </dependency>

    <dependency>
      <groupId>org.powermock</groupId>
      <artifactId>powermock-module-junit4</artifactId>
      <version>1.4.9</version>
      <type>jar</type>
       <scope>test</scope>
    </dependency>

    <dependency>
        <groupId>org.mockito</groupId>
        <artifactId>mockito-all</artifactId>
        <version>1.8.5</version>
        <type>jar</type>
        <scope>test</scope>
    </dependency>

     <dependency>
      <groupId>net.sourceforge.cobertura</groupId>
      <artifactId>cobertura</artifactId>
      <version>1.9.4.1</version>
    </dependency>

  </dependencies>

При сборке из CLI я получаю следующую ошибку:

Tests in error:
  Test mechanism: java.lang.ClassNotFoundException: org.mockito.internal.progres
s.ThreadSafeMockingProgress

Кто-нибудь знает, почему я получаю эту ошибку? Помощь очень приветствуется...


person onlythoughtworks    schedule 25.10.2011    source источник


Ответы (3)


Вам нужно добавить Dexmaker в свои зависимости следующим образом:

    <dependency>
        <groupId>org.mockito</groupId>
        <artifactId>mockito-all</artifactId>
        <version>1.9.5</version>
    </dependency>
    <dependency>
        <groupId>com.google.dexmaker</groupId>
        <artifactId>dexmaker</artifactId>
        <version>1.0</version>
    </dependency>
    <dependency>
        <groupId>com.google.dexmaker</groupId>
        <artifactId>dexmaker-mockito</artifactId>
        <version>1.0</version>
    </dependency>

Однако я думаю, что это не работает с Powermock. Этот сообщение может вам помочь.

person Mickael M.    schedule 10.12.2012

Ваша конфигурация maven выглядит правильной, кроме org.mockito.internal.progress.ThreadSafeMockingProgress, она не должна отсутствовать.

Какую версию mockito вы видите при выполнении следующей команды?

mvn dependency:build-classpath -DincludeScope=test
person Brice    schedule 25.10.2011
comment
Спасибо за ваш ответ, но зависимость mvn: build-classpath дает мне следующий артефакт для mockito: .m2\repository\org\mockito\mockito-all\1.8.5\mockito-all-1.8.5.jar - person onlythoughtworks; 25.10.2011
comment
Я не могу точно определить проблему, вы должны попытаться сделать простой тест, работающий в сборке maven, а затем добавить несколько функций/зависимостей, пока тест не сломается. - person Brice; 26.10.2011
comment
Да, я должен пойти по этому пути, и я забыл упомянуть, что тест действительно выполняется, я вижу делегированный вывод журнала в консоли, все 11 тестов выполняются, но всегда эта одна ошибка... - person onlythoughtworks; 26.10.2011
comment
Может быть совет, я вижу, у вас есть cobertura здесь, если у вас есть раздел отчетности в вашем pom, попробуйте удалить его. - person Brice; 26.10.2011

На всякий случай, если это случайно кому-то поможет, я преодолел ту же ошибку, закомментировав конфигурацию плагина Surefire.

У меня была такая же ошибка, я проанализировал пути к классам Eclipse/Maven, не нашел разницы (кроме записей «/eclipse/configuration/org.eclipse.osgi/bundles/320/1/.cp/»).

В моем случае я ранее отключил тестовое разветвление для плагина Surefire в POM (для устранения другой проблемы). Я подумал, что просто попробую прокомментировать это, и это снова заработает. Случайно, но я решил передать это дальше.

Для полноты закомментированная конфигурация была следующей:

<!--
        <plugin>
            <groupId>org.apache.maven.plugins</groupId>
            <artifactId>maven-surefire-plugin</artifactId>
            <version>2.7.2</version>
            <configuration>
                <forkMode>never</forkMode>
            </configuration>
        </plugin>
-->
person David Carboni    schedule 31.10.2011