Immer javassist.NotFoundException mit PowerMock und PowerRule in JUnit mit Mockito

Habe ich integriert PowerMock und PowerRule in mit JUnit Mockito.

Hier sind meine Abhängigkeiten:

<dependency>
        <groupId>javassist</groupId>
        <artifactId>javassist</artifactId>
        <version>3.12.0.GA</version>
      </dependency>
<dependency>
        <groupId>asm</groupId>
        <artifactId>asm</artifactId>
        <version>3.3.1</version>
</dependency>

 <dependency>
        <groupId>cglib</groupId>
        <artifactId>cglib</artifactId>
        <version>2.2.2</version>
 </dependency>
 <dependency>
        <groupId>org.powermoc</groupId>
    <artifactId>powermock-module-junit4</artifactId>
    <version>1.4.12</version>
    <scope>test</scope>
    </dependency>
 <dependency>
    <groupId>org.powermock</groupId>
    <artifactId>powermock-api-mockito</artifactId>
    <version>1.4.12</version>
    <scope>test</scope>
 </dependency>
 <dependency>
       <groupId>org.powermock</groupId>
       <artifactId>powermock-module-junit4-rule</artifactId>
       <version>1.4.12</version>
       <scope>test</scope>
 </dependency>
 <dependency>
        <groupId>org.powermock</groupId>
        <artifactId>powermock-classloading-objenesis</artifactId>
        <version>1.4.12</version>
        <scope>test</scope>
 </dependency>

Meine test-Klasse ist:

public class TestClass extends AbstractShiroTest{
    @Rule
    public PowerMockRule rule = new PowerMockRule();
    @Autowired
    SomeService someService;
    @Before

    public void setUp(){
    Map<String, Object> newMap = new HashMap<String, Object>();
    newMap.put("userTimeZone", "Asia/Calcutta");
    Subject subjectUnderTest = mock(Subject.class);
             when(subjectUnderTest.getPrincipal()).thenReturn(LMPTestConstants.USER_NAME);
    Session session = mock(Session.class);
    when(session.getAttribute(LMPCoreConstants.USER_DETAILS_MAP)).thenReturn(newMap);
    when(subjectUnderTest.getSession(false)).thenReturn(session);
    setSubject(subjectUnderTest);
    PowerMockito.mockStatic(CasSessionUtil.class);
    when(CasSessionUtil.getCarrierId()).thenReturn(1L);
}

  @Test

public void myTestMethod()  {
someService.doSomething();
 }
}

doSomething ist der Aufruf einer statischen Methode, die ich brauche, zu verspotten.
Wenn ich mit meinem test-Fall, bekomme ich javassist.NotFoundException: $Proxy88.

Volle stack-trace:

java.lang.RuntimeException: javassist.NotFoundException: $Proxy88
bei org.powermock.core.classloader.MockClassLoader.loadUnmockedClass(MockClassLoader.java:187)
bei org.powermock.core.classloader.MockClassLoader.loadModifiedClass(MockClassLoader.java:147)
bei org.powermock.core.classloader.DeferSupportingClassLoader.loadClass(DeferSupportingClassLoader.java:67)
bei java.lang.ClassLoader.loadClass(ClassLoader.java:252)
bei java.lang.ClassLoader.loadClassInternal(ClassLoader.java:320)
bei java.lang.Klasse.forName0(Native-Methode)
bei java.lang.Klasse.forName(Class.java:247)
bei org.powermock.api.Unterstützung.ClassLoaderUtil.loadClass(ClassLoaderUtil.java:66)
bei org.powermock.api.Unterstützung.ClassLoaderUtil.loadClass(ClassLoaderUtil.java:26)
bei org.powermock.zum laden von Klassen.DeepCloner.cloneFields(DeepCloner.java:243)
bei org.powermock.zum laden von Klassen.DeepCloner.performClone(DeepCloner.java:128)
bei org.powermock.zum laden von Klassen.DeepCloner.cloneFields(DeepCloner.java:248)
bei org.powermock.zum laden von Klassen.DeepCloner.performClone(DeepCloner.java:128)
bei org.powermock.zum laden von Klassen.DeepCloner.cloneFields(DeepCloner.java:248)
bei org.powermock.zum laden von Klassen.DeepCloner.performClone(DeepCloner.java:128)
bei org.powermock.zum laden von Klassen.DeepCloner.cloneFields(DeepCloner.java:248)
bei org.powermock.zum laden von Klassen.DeepCloner.performClone(DeepCloner.java:128)
bei org.powermock.zum laden von Klassen.DeepCloner.cloneFields(DeepCloner.java:248)
bei org.powermock.zum laden von Klassen.DeepCloner.performClone(DeepCloner.java:128)
bei org.powermock.zum laden von Klassen.DeepCloner.cloneFields(DeepCloner.java:248)
bei org.powermock.zum laden von Klassen.DeepCloner.performClone(DeepCloner.java:128)
bei org.powermock.zum laden von Klassen.DeepCloner.cloneFields(DeepCloner.java:248)
bei org.powermock.zum laden von Klassen.DeepCloner.performClone(DeepCloner.java:128)
bei org.powermock.zum laden von Klassen.DeepCloner.clone(DeepCloner.java:82)
bei org.powermock.zum laden von Klassen.DeepCloner.clone(DeepCloner.java:69)
bei org.powermock.zum laden von Klassen.ClassloaderExecutor.execute(ClassloaderExecutor.java:89)
bei org.powermock.zum laden von Klassen.ClassloaderExecutor.execute(ClassloaderExecutor.java:78)
bei org.powermock.Module.junit4.Regel.PowerMockStatement.bewerten(PowerMockRule.java:49)
bei org.springframework.test.Kontext.junit4.Aussagen.SpringRepeat.bewerten(SpringRepeat.java:72)
bei org.springframework.test.context.junit4.SpringJUnit4ClassRunner.runChild(SpringJUnit4ClassRunner.java:231)
bei org.junit.die Läufer.BlockJUnit4ClassRunner.runChild(BlockJUnit4ClassRunner.java:50)
bei org.junit.die Läufer.ParentRunner$3.run(ParentRunner.java:193)
bei org.junit.die Läufer.ParentRunner$1.Zeitplan(ParentRunner.java:52)
bei org.junit.die Läufer.ParentRunner.runChildren(ParentRunner.java:191)
bei org.junit.die Läufer.ParentRunner.access$000(ParentRunner.java:42)
bei org.junit.die Läufer.ParentRunner$2.bewerten(ParentRunner.java:184)
bei org.springframework.test.context.junit4.statements.RunBeforeTestClassCallbacks.evaluate(RunBeforeTestClassCallbacks.java:61)
bei org.junit.intern.die Läufer.Aussagen.RunAfters.bewerten(RunAfters.java:31)
bei org.springframework.test.context.junit4.statements.RunAfterTestClassCallbacks.evaluate(RunAfterTestClassCallbacks.java:71)
bei org.junit.die Läufer.ParentRunner.run(ParentRunner.java:236)
bei org.springframework.test.Kontext.junit4.SpringJUnit4ClassRunner.run(SpringJUnit4ClassRunner.java:174)
bei org.eclipse.jdt.intern.junit4.runner.JUnit4TestReference.run(JUnit4TestReference.java:50)
bei org.eclipse.jdt.intern.junit.runner.TestExecution.run(TestExecution.java:38)
bei org.eclipse.jdt.intern.junit.runner.RemoteTestRunner.runTests(RemoteTestRunner.java:467)
bei org.eclipse.jdt.intern.junit.runner.RemoteTestRunner.runTests(RemoteTestRunner.java:683)
bei org.eclipse.jdt.intern.junit.runner.RemoteTestRunner.run(RemoteTestRunner.java:390)
bei org.eclipse.jdt.intern.junit.runner.RemoteTestRunner.main(RemoteTestRunner.java:197)
Verursacht durch: javassist.NotFoundException: $Proxy88
bei javassist.ClassPool.bekommen(ClassPool.java:436)
bei org.powermock.core.classloader.MockClassLoader.loadUnmockedClass(MockClassLoader.java:180)
... 46 mehr

Wenn ich die Abhängigkeit zu

<dependency>
            <groupId>org.powermock</groupId>
            <artifactId>powermock-classloading-xstream</artifactId>
            <version>1.4.12</version>
            <scope>test</scope>
        </dependency>

dann bekomme ich eine andere exception. Bitte sehen https://stackoverflow.com/questions/12176049/suggest-work-around-for-com-thoughtworks-xstream-converters-conversionexception (gelöscht ALSO Frage, erfordert 10k).

Ich habe sogar versucht mit javassist version 15, aber das hat das gleiche problem.

InformationsquelleAutor Bhuvan | 2012-08-30
Schreibe einen Kommentar