/*
 * JBoss, the OpenSource J2EE webOS
 *
 * Distributable under LGPL license.
 * See terms of license at gnu.org.
 */
package org.jboss.test.aop.bean;

import org.jboss.logging.Logger;
import org.jboss.system.ServiceMBeanSupport;

import javax.management.MBeanRegistration;
import javax.management.MBeanServer;
import javax.management.ObjectName;

/**
 * @author <a href="mailto:bill@jboss.org">Bill Burke</a>
 * @version $Revision: 1.5 $
 * @see Monitorable
 */
public class TxLockTester
extends ServiceMBeanSupport
implements TxLockTesterMBean, MBeanRegistration
{
   // Constants ----------------------------------------------------
   // Attributes ---------------------------------------------------
   static Logger log = Logger.getLogger(TxLockTester.class);
   MBeanServer m_mbeanServer;

   // Static -------------------------------------------------------
   
   // Constructors -------------------------------------------------
   public TxLockTester()
   {}
   
   // Public -------------------------------------------------------
   
   // MBeanRegistration implementation -----------------------------------
   public ObjectName preRegister(MBeanServer server, ObjectName name)
   throws Exception
   {
      m_mbeanServer = server;
      return name;
   }

   public void postRegister(Boolean registrationDone)
   {}

   public void preDeregister() throws Exception
   {}

   public void postDeregister()
   {}

   protected void startService()
   throws Exception
   {
   }

   protected void stopService()
   {
   }

   boolean failed = false;

   public class LockThread implements Runnable
   {
      TxLockedPOJO pojo;

      public LockThread(TxLockedPOJO pojo)
      {
         this.pojo = pojo;
      }

      public void run()
      {
         try
         {
            // A lock should be held
            pojo.setField(5);
         }
         catch (Exception ex)
         {
            failed = true;
            log.error("thread failed", ex);
         }
      }
   }

   public class AnnotatedLockThread implements Runnable
   {
      AnnotatedTxLockedPOJO pojo;

      public AnnotatedLockThread(AnnotatedTxLockedPOJO pojo)
      {
         this.pojo = pojo;
      }

      public void run()
      {
         try
         {
            // A lock should be held
            pojo.setField(5);
         }
         catch (Exception ex)
         {
            failed = true;
            log.error("thread failed", ex);
         }
      }
   }

   public void testXml()
   {
      failed = false;
      try
      {
         log.info("TESTING TX LOCK");
         TxLockedPOJO pojo = new TxLockedPOJO();
         Thread t = new Thread(new LockThread(pojo));
         t.start();
         Thread.sleep(1000);
         pojo.setField(6);
         if (failed) throw new RuntimeException("test failed");
      }
      catch (Throwable ex)
      {
         log.error("failed", ex);
         throw new RuntimeException(ex.getMessage());
      }
   }

   public void testAnnotated()
   {
      failed = false;
      try
      {
         log.info("TESTING TX LOCK");
         AnnotatedTxLockedPOJO pojo = new AnnotatedTxLockedPOJO();
         Thread t = new Thread(new AnnotatedLockThread(pojo));
         t.start();
         Thread.sleep(1000);
         pojo.setField(6);
         if (failed) throw new RuntimeException("test failed");
      }
      catch (Throwable ex)
      {
         log.error("failed", ex);
         throw new RuntimeException(ex.getMessage());
      }
   }

}