예제 #1
0
  @Test
  public void testCMTInTxTimeout()
      throws InterruptedException, NamingException, SystemException, NotSupportedException,
          RollbackException, HeuristicRollbackException, HeuristicMixedException {
    /*
    Stateful test Bean.
       */

    UserTransaction userTransaction =
        (UserTransaction) new InitialContext().lookup("javax.transaction.UserTransaction");
    ITimeoutBean simpleTimeoutBean =
        (ITimeoutBean) new InitialContext().lookup("simpleTimeoutBean");
    userTransaction.begin();
    simpleTimeoutBean.init();
    Thread.sleep(200);
    // Initially it should  return a NoSuchEJBException immediately after the lookup but there is a
    // running transaction
    simpleTimeoutBean.ping();
    userTransaction.commit();
    // Now transaction is committed
    Thread.sleep(100);
    try {
      simpleTimeoutBean.ping();
    } catch (NoSuchEJBException e) {
      // Should return a  NoSuchEJBException immediately after the end of the transaction
      return;
    }
    Assert.fail("Timeout exceeded and call to the EJB doesn't throw a NoSuchEJBException");
  }
예제 #2
0
 //    @Test
 public void testZeroTimeout() throws InterruptedException, NamingException {
   /*
    Stateful test Bean.
   */
   ITimeoutBean zeroTimeoutBean = (ITimeoutBean) new InitialContext().lookup("zero-timeout");
   // As the actual resolution is in ms, on some powerful machines we need to sleep the test a
   // little bit to detect the timeout
   Thread.sleep(200);
   try {
     zeroTimeoutBean.ping();
   } catch (NoSuchEJBException e) {
     // Should return a  NoSuchEJBException immediately after the lookup
     return;
   }
   Assert.fail("Timeout exceeded and call to the EJB doesn't throw a NoSuchEJBException");
 }
예제 #3
0
 @Test
 public void testSimpleTimeout() throws InterruptedException, NamingException {
   /*
    Stateful test Bean.
   */
   ITimeoutBean simpleTimeoutBean =
       (ITimeoutBean) new InitialContext().lookup("simpleTimeoutBean");
   simpleTimeoutBean.ping();
   // Sleep for 50 ms
   Thread.sleep(50);
   simpleTimeoutBean.ping();
   // Sleep for 100 ms
   Thread.sleep(100);
   try {
     simpleTimeoutBean.ping();
   } catch (NoSuchEJBException e) {
     return;
   }
   Assert.fail("Timeout exceeded and call to the EJB doesn't throw a NoSuchEJBException");
 }
예제 #4
0
 @Test
 public void testBMTInTxTimeout() throws InterruptedException, NamingException {
   /*
    Stateful test Bean.
   */
   ITimeoutBean inTxTimeoutBean = (ITimeoutBean) new InitialContext().lookup("BMTInTxBean");
   inTxTimeoutBean.init();
   Thread.sleep(200);
   // Initially it should  return a NoSuchEJBException immediately after the lookup but there is a
   // running transaction
   inTxTimeoutBean.ping();
   // Now transaction is committed
   Thread.sleep(100);
   try {
     inTxTimeoutBean.ping();
   } catch (NoSuchEJBException e) {
     // Should return a  NoSuchEJBException immediately after the end of the transaction
     return;
   }
   Assert.fail("Timeout exceeded and call to the EJB doesn't throw a NoSuchEJBException");
 }