Junit бросает java.lang.AbstractMethodError: javax.ws.rs.core.Response $ ResponseBuilder.status - PullRequest
0 голосов
/ 24 января 2019

В настоящее время пишу Junit для нашего кода веб-сервиса.

Код WebService и код Junit записываются в разделе кода

Когда я запускаю Junit, я получаю сообщение об ошибке ниже

java.lang.AbstractMethodError: javax.ws.rs.core.Response$ResponseBuilder.status(ILjava/lang/String;)Ljavax/ws/rs/core/Response$ResponseBuilder;
at javax.ws.rs.core.Response$ResponseBuilder.status(Response.java:921)
at javax.ws.rs.core.Response.status(Response.java:592)
at javax.ws.rs.core.Response.status(Response.java:603)
at javax.ws.rs.core.Response.ok(Response.java:638)
at javax.ws.rs.core.Response.ok(Response.java:650)
at com.renault.rntbci.stl.service.demande.impl.ListDemandServiceImpl.getDemandeListCount(ListDemandServiceImpl.java:281)
at com.renault.rntbci.stl.service.demande.impl.ListDemandeTest.testGetDemandeListCount(ListDemandeTest.java:51)
at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:62)
at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)
at java.lang.reflect.Method.invoke(Method.java:497)
at org.junit.runners.model.FrameworkMethod$1.runReflectiveCall(FrameworkMethod.java:50)
at org.junit.internal.runners.model.ReflectiveCallable.run(ReflectiveCallable.java:12)
at org.junit.runners.model.FrameworkMethod.invokeExplosively(FrameworkMethod.java:47)
at org.junit.internal.runners.statements.InvokeMethod.evaluate(InvokeMethod.java:17)
at org.junit.internal.runners.statements.RunBefores.evaluate(RunBefores.java:26)
at org.junit.runners.ParentRunner.runLeaf(ParentRunner.java:325)
at org.junit.runners.BlockJUnit4ClassRunner.runChild(BlockJUnit4ClassRunner.java:78)
at org.junit.runners.BlockJUnit4ClassRunner.runChild(BlockJUnit4ClassRunner.java:57)
at org.junit.runners.ParentRunner$3.run(ParentRunner.java:290)
at org.junit.runners.ParentRunner$1.schedule(ParentRunner.java:71)
at org.junit.runners.ParentRunner.runChildren(ParentRunner.java:288)
at org.junit.runners.ParentRunner.access$000(ParentRunner.java:58)
at org.junit.runners.ParentRunner$2.evaluate(ParentRunner.java:268)
at org.junit.runners.ParentRunner.run(ParentRunner.java:363)
at org.eclipse.jdt.internal.junit4.runner.JUnit4TestReference.run(JUnit4TestReference.java:86)
at org.eclipse.jdt.internal.junit.runner.TestExecution.run(TestExecution.java:38)
at org.eclipse.jdt.internal.junit.runner.RemoteTestRunner.runTests(RemoteTestRunner.java:459)
at org.eclipse.jdt.internal.junit.runner.RemoteTestRunner.runTests(RemoteTestRunner.java:678)
at org.eclipse.jdt.internal.junit.runner.RemoteTestRunner.run(RemoteTestRunner.java:382)
at org.eclipse.jdt.internal.junit.runner.RemoteTestRunner.main(RemoteTestRunner.java:192)

Один из моих друзей посоветовал мне изменить область для тестирования в pom.xml для версии jax rs, как показано ниже.

    <dependency>
        <groupId>org.jboss.resteasy</groupId>
        <artifactId>jaxrs-api</artifactId>
        <scope>test</scope>
        <version>2.3.7.Final</version>
    </dependency>

Но все еще сохраняется та же ошибка. Пожалуйста, кто-нибудь, пожалуйста, помогите мне с решением.

Заранее большое спасибо.

Примечание: Это существующее приложение, и я новичок в этом проекте с Java 1.7

public Response someMethod(String stringValue){

    Map<String, Long> outputMap = new TreeMap<String, Long>();

    try {
        Long outputValue = service.getCount(stringValue);
        //this call goes to a service and gets the db count for a table
        outputMap.put("listCount", outputValue);

    } catch (Exception e) {
        logger.info(e.getMessage(), e); 
    }
    return Response.ok(outputMap).build();
}

И код Junit

@Mock
Service service;

@Mock
Response res;
@Test
public void testSomeMethod() throws SQLException {
    String stringValue="12";
    Long returnValue=10L;

    when(service.getCount(stringValue)).thenReturn(returnValue);
    res=obj.someMethod(stringValue);
    Assert.assertNotNull(res);
}

1 Ответ

0 голосов
/ 25 января 2019

Я подозреваю, что здесь происходит то, что у вас есть две разные версии файла JAR, содержащие класс javax.ws.rs.core.Response$ResponseBuilder.Между двумя версиями этого класса, который вы плаваете, абстрактный метод status() изменился.Вам нужно просмотреть список зависимостей Maven, выполнив команду mvn dependency:tree согласно этому ответу .Вам необходимо идентифицировать две разные версии JAR, содержащие два разных класса javax.ws.rs.core.Response$ResponseBuilder.Исключите версию зависимости, которую вы не хотите, и сохраните версию, которую вы хотите сохранить.

Это может быть так же просто, как удалить файл jboss-jaxrs-api_1.1_spec Jar, но в зависимости от того, какие другие зависимости у вас есть (и какие переходныезависимости) может быть что-то большее, чем это.

...