Sziasztok!
A HA3 CBTG részéhez evosuite eszközt szeretnénk használni, mely többé kevésbé sikerült is, készültek generált tesztjeink. Azonban ha egyszerre futtatjuk a korábbi tesztekkel az újonnan generáltakat (pl. mvn test) akkor a régi tesztek nem futnak le, a következő hibát adják:
org.mockito.exceptions.base.MockitoException:
ClassCastException occurred while creating the mockito mock :
class to mock : 'hu.bme.mit.swsv.ris.common.logging.LoggerWrapper', loaded by classloader : 'sun.misc.Launcher$AppClassLoader@4f3f5b24'
created class : 'hu.bme.mit.swsv.ris.common.logging.LoggerWrapper$MockitoMock$1169644998', loaded by classloader : 'net.bytebuddy.dynamic.loading.MultipleParentClassLoader@302c971f'
proxy instance class : 'hu.bme.mit.swsv.ris.common.logging.LoggerWrapper$MockitoMock$1169644998', loaded by classloader : 'net.bytebuddy.dynamic.loading.MultipleParentClassLoader@302c971f'
instance creation by : ObjenesisInstantiator
You might experience classloading issues, please ask the mockito mailing-list.
at hu.bme.mit.swsv.ris.tsm.test.SafetyLogicLocalTest.setUp(SafetyLogicLocalTest.java:47)
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.RunBefores.evaluate(RunBefores.java:24)
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)
Caused by: java.lang.ClassCastException: hu.bme.mit.swsv.ris.common.logging.LoggerWrapper$MockitoMock$1169644998 cannot be cast to org.mockito.internal.creation.bytebuddy.MockAccess
at org.mockito.internal.creation.bytebuddy.SubclassByteBuddyMockMaker.createMock(SubclassByteBuddyMockMaker.java:48)
at org.mockito.internal.creation.bytebuddy.ByteBuddyMockMaker.createMock(ByteBuddyMockMaker.java:25)
at org.mockito.internal.util.MockUtil.createMock(MockUtil.java:35)
at org.mockito.internal.MockitoCore.mock(MockitoCore.java:69)
at org.mockito.Mockito.mock(Mockito.java:1895)
at org.mockito.Mockito.mock(Mockito.java:1804)
... 24 more
Ha külön-külön kézzel futtatjuk őket, minden rendben. Ezt a tutorialt követtük, melyben elvileg külön kitértek rá, hogy a surefire plugin-nal lehet manuális és generált teszteket együtt futtatni. Próbálkoztunk a test scaffolding különböző paraméterezésével is, de sajnos nem javította meg a problémát.
Találkozott esetleg valaki hasonló hibával? Van valami ötlet mivel érdemes még próbálkozni?
Köszi!
loremipsum csapat