我有以下單元測試給我一個空指針異常。調試器會在創建連接工廠的行之後進入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
)