2014-12-02 135 views
0

我有以下單元測試給我一個空指針異常。調試器會在創建連接工廠的行之後進入finally塊。這裏的測試:在activemq調試單元測試時獲得空指針異常

@Test 
    public void receiveMessage() throws Exception { 
      MessageConsumer consumer = null; 
      ConnectionFactory connectionFactory = null; 
     Connection connection = null; 
     Session session = null; 
     Destination destination = null; 
      try { 
        connectionFactory = new ActiveMQConnectionFactory(
         "tcp://localhost:61616"); 
       connection = connectionFactory.createConnection("username","pwd"); 
       connection.start(); 
       session = connection.createSession(true, 
         Session.AUTO_ACKNOWLEDGE); 

       destination = session 
            .createQueue("myQueue"); 
        logger.info("Starting consumer"); 
        consumer = session 
            .createConsumer(destination); 

        Message m = consumer.receive(); 
        logger.info("Received message:" + m); 
      } 


      } catch (Exception e) { 
        logger.error("", e); 
      } finally { 
        consumer.close(); 
        session.close(); 
        connection.stop(); 
        connection.close(); 
      } 
    } 

這裏的堆棧跟蹤:

顯示java.lang.NullPointerException在 ClassName.receiveMessage(ClassName.java:62) 在sun.reflect.NativeMethodAccessorImpl.invoke0(母語法)維持在在 java.lang.reflect.Method.invoke(來源不明) sun.reflect.DelegatingMethodAccessorImpl.invoke(來源不明) sun.reflect.NativeMethodAccessorImpl.invoke(來源不明)在 org.junit.runners .model.FrameworkMethod $ 1.runR eflectiveCall(FrameworkMethod.java:47) 在 org.junit.internal.runners.model.ReflectiveCallable.run(ReflectiveCallable.java:12) 在 org.junit.runners.model.FrameworkMethod.invokeExplosively(FrameworkMethod.java: 44) 在 org.junit.internal.runners.statements.InvokeMethod.evaluate(InvokeMethod.java:17) 在 org.junit.internal.runners.statements.RunAfters.evaluate(RunAfters.java:27) 在org.junit.runners.ParentRunner.runLeaf(ParentRunner.java:271)在 org.junit.runners.BlockJUnit4ClassRunner.runChild(BlockJUnit4ClassRunner.java:70) 在 org.junit.runners.BlockJUnit4ClassRunner.runChild(BlockJUnit4ClassRunner.java :50) at org.junit.runners.ParentRunner $ 3.run(ParentRunner.java:238)at org.junit.runners.ParentRunner $ 1.schedule(ParentRunner.java:63)at org.junit.runners.ParentRunner.runChildren( org.junit.runners.ParentRunner.access $ 000(ParentRunner.java:53)at org.junit.runners.ParentRunner $ 2.evaluate(ParentRunner.java:229)at org.junit。 runner.ParentRunner.run(ParentRunner.java:309)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(Rem oteTestRunner.java:459) 在 org.eclipse.jdt.internal.junit.runner.RemoteTestRunner.runTests(RemoteTestRunner.java:675) 在 org.eclipse.jdt.internal.junit.runner.RemoteTestRunner.run( RemoteTestRunner.java:382) 在 org.eclipse.jdt.internal.junit.runner.RemoteTestRunner.main(RemoteTestRunner.java:192

回答

0

在單元測試中實際連接不應該被用來,即你正試圖在單元測試用例中連接到BrokerURL,這不是單元測試的目的。

在您需要模擬的外部連接這樣的情況下,使用庫,如Easymock+PowermockMockito

和關於空指針異常,是你的經紀人嗎?和用戶名,密碼正確,請檢查這些