/*
* #%L
* Nazgul Project: nazgul-core-messaging-test
* %%
* Copyright (C) 2010 - 2017 jGuru Europe AB
* %%
* Licensed under the jGuru Europe AB license (the "License"), based
* on Apache License, Version 2.0; you may not use this file except
* in compliance with the License.
*
* You may obtain a copy of the License at
*
* http://www.jguru.se/licenses/jguruCorporateSourceLicense-2.0.txt
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
* #L%
*
*/
package se.jguru.nazgul.test.messaging.artemis;
import org.junit.After;
import org.junit.Assert;
import org.junit.Before;
import org.junit.Test;
import se.jguru.nazgul.test.messaging.MessageBroker;
import javax.jms.Connection;
import javax.jms.MessageProducer;
import javax.jms.Queue;
import javax.jms.Session;
import javax.jms.TextMessage;
import java.util.List;
/**
* @author <a href="mailto:lj@jguru.se">Lennart Jörelid</a>, jGuru Europe AB
*/
public class T_AbstractArtemisTestTest {
// Shared state
private MockArtemisTest unitUnderTest;
private MessageBroker broker;
@Before
public void setupSharedState() {
unitUnderTest = new MockArtemisTest(false);
broker = unitUnderTest.getBroker();
}
@After
public void teardownSharedState() throws Exception {
unitUnderTest.stopJmsBroker();
}
@Test
public void validateBrokerTypeAndLifecycle() throws Exception {
// Assemble
// Act
unitUnderTest.startJmsBroker();
unitUnderTest.stopJmsBroker();
// Assert
Assert.assertNotNull(broker);
Assert.assertTrue(broker instanceof ArtemisBroker);
final List<String> callTrace = unitUnderTest.callTrace;
Assert.assertEquals(2, callTrace.size());
Assert.assertEquals("setupServices", callTrace.get(0));
Assert.assertEquals("tearDownServices", callTrace.get(1));
}
@Test
public void validateProperCreationOfNonTransactedJmsObjects() throws Exception {
// Assemble
// Assert
unitUnderTest.startJmsBroker();
final Connection connection = unitUnderTest.createConnection();
final Session session = unitUnderTest.createSession(connection);
final Queue clientSideRequestQueue = session.createTemporaryQueue();
final MessageProducer requestProducer = session.createProducer(clientSideRequestQueue);
final TextMessage message = session.createTextMessage("fooBar!");
requestProducer.send(message);
unitUnderTest.stopJmsBroker();
// Act
Assert.assertNotNull(connection);
Assert.assertNotNull(session);
Assert.assertNotNull(requestProducer);
Assert.assertNotNull(message);
}
}