001: /**
002: * EasyBeans
003: * Copyright (C) 2006 Bull S.A.S.
004: * Contact: easybeans@ow2.org
005: *
006: * This library is free software; you can redistribute it and/or
007: * modify it under the terms of the GNU Lesser General Public
008: * License as published by the Free Software Foundation; either
009: * version 2.1 of the License, or any later version.
010: *
011: * This library is distributed in the hope that it will be useful,
012: * but WITHOUT ANY WARRANTY; without even the implied warranty of
013: * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
014: * Lesser General Public License for more details.
015: *
016: * You should have received a copy of the GNU Lesser General Public
017: * License along with this library; if not, write to the Free Software
018: * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307
019: * USA
020: *
021: * --------------------------------------------------------------------------
022: * $Id: TestTransactionMDB.java 1970 2007-10-16 11:49:25Z benoitf $
023: * --------------------------------------------------------------------------
024: */package org.ow2.easybeans.tests.transaction.beanmanaged;
025:
026: import static org.ow2.easybeans.tests.common.ejbs.entity.callbacklogger.CallbackType.ON_MESSAGE;
027: import static org.ow2.easybeans.tests.common.helper.EJBHelper.getBeanRemoteInstance;
028:
029: import java.util.ArrayList;
030: import java.util.List;
031:
032: import org.ow2.easybeans.tests.common.ejbs.entity.callbacklogger.OperationType;
033: import org.ow2.easybeans.tests.common.ejbs.mdb.beanmanaged.transaction.MDBBMTransaction;
034: import org.ow2.easybeans.tests.common.ejbs.stateless.containermanaged.callbacklogger.ItfCallbackLoggerAccess;
035: import org.ow2.easybeans.tests.common.ejbs.stateless.containermanaged.callbacklogger.SLSBCallbackLoggerAccess;
036: import org.ow2.easybeans.tests.common.jms.JMSManager;
037: import org.testng.annotations.AfterClass;
038: import org.testng.annotations.AfterMethod;
039: import org.testng.annotations.BeforeClass;
040: import org.testng.annotations.Test;
041:
042: /**
043: * Verifies if message-driven bean with bean-managed transaction is
044: * following the JSR 220. The items covered in this test are: 5.4.12
045: * @reference JSR 220-PROPOSED FINAL
046: * @requirement Application Server must be running.<br>
047: * MDB:<li>org.ow2.easybeans.tests.common.ejbs.mdb.beanmanaged.transaction.MDBBMTransaction</li>
048: * SLSB: <li>org.ow2.easybeans.tests.common.ejbs.stateless.containermanaged.inheritance.SLSBCMTInheritance</li>
049: * (Ant task: install.jar.tests.transaction)
050: * @author Eduardo Studzinski Estima de Castro
051: * @author Gisele Pinheiro Souza
052: *
053: */
054: public class TestTransactionMDB {
055:
056: /**
057: * JMS Manager.
058: */
059: private JMSManager jmsQueue;
060:
061: /**
062: * Logger bean.
063: */
064: private ItfCallbackLoggerAccess beanLogger;
065:
066: /**
067: * Creates the JMS manager.
068: * @throws Exception if there is a problem.
069: */
070: @BeforeClass
071: public void startUp00() throws Exception {
072: jmsQueue = new JMSManager(
073: JMSManager.DEFAULT_QUEUE_CONNECTION_FACTORY,
074: JMSManager.DEFAULT_QUEUE);
075: beanLogger = getBeanRemoteInstance(
076: SLSBCallbackLoggerAccess.class,
077: ItfCallbackLoggerAccess.class);
078: }
079:
080: /**
081: * Verifies if the bean-managed transaction with
082: * message-driven bean is working properly.
083: * @input a message
084: * @output a logged onMessage() event
085: * @throws Exception if a problem occurs.
086: */
087: @Test
088: public void testBeanManaged00() throws Exception {
089: jmsQueue.sendControlMessage(MDBBMTransaction.MESSAGE_TYPE,
090: OperationType.UNDEFINED);
091:
092: // Verifies if the message was received
093: List<String> arEvent = new ArrayList<String>();
094:
095: arEvent.add(MDBBMTransaction.class.getName());
096:
097: beanLogger.verifyCallbackOrder(MDBBMTransaction.class,
098: ON_MESSAGE, arEvent.toArray(new String[0]));
099: }
100:
101: /**
102: * Clears logs.
103: * @throws Exception if a problem occurs.
104: */
105: @AfterMethod
106: public void tearDown() throws Exception {
107: beanLogger.deleteAll();
108: }
109:
110: /**
111: * Clears logs.
112: * @throws Exception if a problem occurs.
113: */
114: @AfterClass
115: public void tearDownClass() throws Exception {
116: jmsQueue.close();
117: }
118: }
|