3 votes

3 jumelages attendus, 4 enregistrés

Je reçois cette exception pendant l'enregistrement fictif. J'ai essayé de trouver une solution dans ce forum et je me suis assuré que je n'avais pas oublié un autre paramètre.

L'attente fictive ci-dessous donne l'erreur.

EasyMock.expect(slotManager.addSlotPageletBinding(EasyMock.isA(String.class), EasyMock.isA(String.class), EasyMock.isA(helloWorld.class))).andReturn(true);

Avant cette déclaration, j'ai une autre attente fantaisie sur la même méthode avec DEUX paramètres (méthode surchargée). Ci-dessous se trouve cette attente fantaisie.

EasyMock.expect(slotManager.addSlotPageletBinding(EasyMock.isA(String.class),EasyMock.isA(String.class))).andReturn(true).anyTimes();

Quelqu'un peut-il me guider à ce sujet ? Merci.

java.lang.IllegalStateException: 3 matchers expected, 4 recorded.
    at org.easymock.internal.ExpectedInvocation.createMissingMatchers(ExpectedInvocation.java:56)
    at org.easymock.internal.ExpectedInvocation.<init>(ExpectedInvocation.java:48)
    at org.easymock.internal.ExpectedInvocation.<init>(ExpectedInvocation.java:40)
    at org.easymock.internal.RecordState.invoke(RecordState.java:76)
    at org.easymock.internal.MockInvocationHandler.invoke(MockInvocationHandler.java:38)
    at org.easymock.internal.ObjectMethodsFilter.invoke(ObjectMethodsFilter.java:72)
    at org.easymock.classextension.internal.ClassProxyFactory$1.intercept(ClassProxyFactory.java:79)
    at com.amazon.inca.application.SlotManager$$EnhancerByCGLIB$$3bf5ac02.addSlotPageletBinding(<generated>)
    at com.amazon.iris3.apps.Iris3YourAccountApplicationTest.testBuildIncaViewConfiguration(Iris3YourAccountApplicationTest.java:107)
    at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
    at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:39)
    at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:25)
    at java.lang.reflect.Method.invoke(Method.java:597)
    at junit.framework.TestCase.runTest(TestCase.java:168)
    at junit.framework.TestCase.runBare(TestCase.java:134)
    at junit.framework.TestResult$1.protect(TestResult.java:110)
    at junit.framework.TestResult.runProtected(TestResult.java:128)
    at junit.framework.TestResult.run(TestResult.java:113)
    at junit.framework.TestCase.run(TestCase.java:124)
    at junit.framework.TestSuite.runTest(TestSuite.java:232)
    at junit.framework.TestSuite.run(TestSuite.java:227)
    at org.junit.internal.runners.JUnit38ClassRunner.run(JUnit38ClassRunner.java:83)
    at org.eclipse.jdt.internal.junit4.runner.JUnit4TestReference.run(JUnit4TestReference.java:46)
    at org.eclipse.jdt.internal.junit.runner.TestExecution.run(TestExecution.java:38)
    at org.eclipse.jdt.internal.junit.runner.RemoteTestRunner.runTests(RemoteTestRunner.java:467)
    at org.eclipse.jdt.internal.junit.runner.RemoteTestRunner.runTests(RemoteTestRunner.java:683)
    at org.eclipse.jdt.internal.junit.runner.RemoteTestRunner.run(RemoteTestRunner.java:390)
    at org.eclipse.jdt.internal.junit.runner.RemoteTestRunner.main(RemoteTestRunner.java:197)

1voto

Constantiner Points 12503

Le problème est que vous avez enregistré 3 attentes (appels) de votre fantaisie mais pendant l'exécution du test, il y a eu 4 appels des méthodes de la fantaisie. Vous avez donc manqué un appel quelque part. Essayez de lire davantage votre code sous test et découvrez l'appel manquant. Ou utilisez le débogueur pour le découvrir.

Prograide.com

Prograide est une communauté de développeurs qui cherche à élargir la connaissance de la programmation au-delà de l'anglais.
Pour cela nous avons les plus grands doutes résolus en français et vous pouvez aussi poser vos propres questions ou résoudre celles des autres.

Powered by:

X