这个问题通常是由于测试中的 JMSMessagingTemplate 实例没有完全注入或初始化导致的。为了解决这个问题,您可以使用 Spring 的测试注释 @DirtiesContext 来标记一些有问题的测试方法,这样每次运行这些测试时都会重新创建 Spring 应用程序上下文,从而确保每个测试方法都使用新的 JMSMessagingTemplate 实例。同时,确保您的测试中注入的 JMSMessagingTemplate 具有完全初始化的连接工厂和目的地,示例如下:
@RunWith(SpringRunner.class)
@SpringBootTest
@DirtiesContext(classMode = ClassMode.AFTER_EACH_TEST_METHOD)
public class JmsTest {
private static final String QUEUE_NAME = "test";
@Autowired
private JmsMessagingTemplate jmsMessagingTemplate;
@Autowired
private ConnectionFactory connectionFactory;
@Autowired
private Queue queue;
@Test
public void testJmsSendAndReceive() {
jmsMessagingTemplate.convertAndSend(queue, "hello");
String received = (String) jmsMessagingTemplate.receiveAndConvert(queue);
assertEquals("hello", received);
}
}
在此示例中,@DirtiesContext
注释标记了 JmsTest
类中的所有测试方法,每次运行一个测试方法时都会重建 Spring 上下文,以确保 JmsMessagingTemplate
实例不受旧实例的状态污染。
请注意,这个解决方法存在一些缺点,例如显著增加测试运行时间等。因此,建议您在使用之前权衡利弊,特别是当您的测试环境中存在高并发访问 JMS 服务的情况时。