/******************************************************************************* * Copyright (c) 2005, 2014 springside.github.io * * Licensed under the Apache License, Version 2.0 (the "License"); *******************************************************************************/ package org.springside.examples.showcase.demos.jms; import static org.assertj.core.api.Assertions.*; import javax.annotation.Resource; import javax.jms.Destination; import javax.jms.JMSException; import javax.jms.MapMessage; import javax.jms.Message; import javax.jms.Session; import org.junit.Test; import org.junit.experimental.categories.Category; import org.springframework.beans.factory.annotation.Autowired; import org.springframework.jms.core.JmsTemplate; import org.springframework.jms.core.MessageCreator; import org.springframework.test.annotation.DirtiesContext; import org.springframework.test.context.ContextConfiguration; import org.springside.examples.showcase.demos.jms.advanced.AdvancedNotifyMessageListener; import org.springside.examples.showcase.demos.jms.advanced.AdvancedNotifyMessageProducer; import org.springside.examples.showcase.entity.User; import org.springside.modules.test.category.UnStable; import org.springside.modules.test.log.LogbackListAppender; import org.springside.modules.test.spring.SpringContextTestCase; import org.springside.modules.utils.Threads; @Category(UnStable.class) @DirtiesContext @ContextConfiguration(locations = { "/applicationContext.xml", "/jms/applicationContext-jms-advanced.xml" }) public class JmsAdvancedTest extends SpringContextTestCase { @Autowired private AdvancedNotifyMessageProducer notifyMessageProducer; @Resource private JmsTemplate advancedJmsTemplate; @Resource private Destination advancedNotifyTopic; @Test public void queueMessage() { Threads.sleep(1000); LogbackListAppender appender = new LogbackListAppender(); appender.addToLogger(AdvancedNotifyMessageListener.class); User user = new User(); user.setName("calvin"); user.setEmail("calvin@sringside.org.cn"); notifyMessageProducer.sendQueue(user); Threads.sleep(1000); assertThat(appender.getFirstMessage()).isEqualTo( "UserName:calvin, Email:calvin@sringside.org.cn, ObjectType:user"); } @Test public void topicMessage() { Threads.sleep(1000); LogbackListAppender appender = new LogbackListAppender(); appender.addToLogger(AdvancedNotifyMessageListener.class); User user = new User(); user.setName("calvin"); user.setEmail("calvin@sringside.org.cn"); notifyMessageProducer.sendTopic(user); Threads.sleep(1000); assertThat(appender.getFirstMessage()).isEqualTo( "UserName:calvin, Email:calvin@sringside.org.cn, ObjectType:user"); } @Test public void topicMessageWithWrongType() { Threads.sleep(1000); LogbackListAppender appender = new LogbackListAppender(); appender.addToLogger(AdvancedNotifyMessageListener.class); advancedJmsTemplate.send(advancedNotifyTopic, new MessageCreator() { @Override public Message createMessage(Session session) throws JMSException { MapMessage message = session.createMapMessage(); message.setStringProperty("objectType", "role"); return message; } }); Threads.sleep(1000); assertThat(appender.isEmpty()).isTrue(); } }