2015-08-17 11 views
5

Sto provando a simulare la classe javax.faces.component.UIInput.Mocking della classe UIInput per i test

La mia classe è come sotto

public class MyBean{ 

    private UIInput someInput; 

    //setters and getters 

} 

Test case

UIInput mockedVale = Mockito.mock(UIInput.class); 
MyBean myBean = new MyBean(); 
myBean.setSomeInput(mockedVale); 

Qualcuno può aiutarmi a risolvere questo

java.lang.ExceptionInInitializerError 
    at sun.reflect.GeneratedSerializationConstructorAccessor3.newInstance(Unknown Source) 
    at java.lang.reflect.Constructor.newInstance(Constructor.java:422) 
    at org.objenesis.instantiator.sun.SunReflectionFactoryInstantiator.newInstance(SunReflectionFactoryInstantiator.java:45) 
    at org.objenesis.ObjenesisBase.newInstance(ObjenesisBase.java:73) 
    at org.mockito.internal.creation.jmock.ClassImposterizer.createProxy(ClassImposterizer.java:142) 
    at org.mockito.internal.creation.jmock.ClassImposterizer.imposterise(ClassImposterizer.java:61) 
    at org.mockito.internal.creation.jmock.ClassImposterizer.imposterise(ClassImposterizer.java:52) 
    at org.mockito.internal.creation.CglibMockMaker.createMock(CglibMockMaker.java:24) 
    at org.mockito.internal.util.MockUtil.createMock(MockUtil.java:32) 
    at org.mockito.internal.MockitoCore.mock(MockitoCore.java:59) 
    at org.mockito.Mockito.mock(Mockito.java:1258) 
    at org.mockito.Mockito.mock(Mockito.java:1135) 
    at se.telenor.ocfd.web.facade.MyBean.<init>(MyBean.java:28) 
    at sun.reflect.NativeConstructorAccessorImpl.newInstance0(Native Method) 
    at sun.reflect.NativeConstructorAccessorImpl.newInstance(NativeConstructorAccessorImpl.java:62) 
    at sun.reflect.DelegatingConstructorAccessorImpl.newInstance(DelegatingConstructorAccessorImpl.java:45) 
    at java.lang.reflect.Constructor.newInstance(Constructor.java:422) 
    at org.junit.runners.BlockJUnit4ClassRunner.createTest(BlockJUnit4ClassRunner.java:217) 
    at org.junit.runners.BlockJUnit4ClassRunner$1.runReflectiveCall(BlockJUnit4ClassRunner.java:266) 
    at org.junit.internal.runners.model.ReflectiveCallable.run(ReflectiveCallable.java:12) 
    at org.junit.runners.BlockJUnit4ClassRunner.methodBlock(BlockJUnit4ClassRunner.java:263) 
    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:50) 
    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:675) 
    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.util.MissingResourceException: Can't find javax.faces.LogStrings bundle 
    at java.util.logging.Logger.setupResourceInfo(Logger.java:1945) 
    at java.util.logging.Logger.<init>(Logger.java:380) 
    at java.util.logging.LogManager.demandLogger(LogManager.java:554) 
    at java.util.logging.Logger.demandLogger(Logger.java:455) 
    at java.util.logging.Logger.getLogger(Logger.java:553) 
    at javax.faces.component.UIComponent.<clinit>(UIComponent.java:116) 
    ... 35 more 

risposta

3

Nella classe UIComponent (che il test usi), c'è una riga statica per l'inizializzazione il Logger:

private static Logger LOGGER = Logger.getLogger("javax.faces.component", 
    "javax.faces.LogStrings"); 

Ciò significa, la classe è alla ricerca di un fascio risorsa nome LogStrings all'interno del pacchetto javax.faces. Nello javax e nella sottodirectory facce e all'interno del file LogStrings.properties. Quindi la tua classe sta anche cercando questo file.

Il vaso facce all'interno del classpath?

2

Come indicato in Niklas P.'s answer, la causa del problema è l'inizializzazione Logger da UIComponent.

Per risolvere il problema, è necessario includere nel progetto jsf-api-xxx.jar. Come spiegato here sull'utilizzo jsf-api-xxx.jar o javax.faces-xxx.jar (motivi di portabilità):

realtà è possibile utilizzare entrambi. Ma il modo consigliato è di includere jsf-api-xxx.jar solo nel classpath della compilation.

In Maven si solo bisogno di aggiungere il seguente dipendenza alla vostra pom.xml:

<dependency> 
    <groupId>com.sun.faces</groupId> 
    <artifactId>jsf-api</artifactId> 
    <version>2.2.8-18</version><!-- the version you are using --> 
    <scope>provided</scope> 
</dependency> 
+1

Per qualsiasi motivo Oracle non include il pacchetto di risorse _LogStrings_ all'interno del suo jar 'javax: javaee-api: 7.0' (è _è incluso nel vaso dei sorgenti! dooh!). L'unico modo per farlo funzionare è includere 'jsf-api-xxx.jar' come menzionato qui. –

0

Ho usato questa ulteriore prova con ambito Maven dipendenza (pom.xml):

<dependency> 
     <groupId>javax.faces</groupId> 
     <artifactId>javax.faces-api</artifactId> 
     <version>2.2</version> 
     <scope>test</scope> 
    </dependency> 
Problemi correlati