package org.jboss.test.txiiop.ejb;
import java.io.ByteArrayInputStream;
import java.io.ByteArrayOutputStream;
import java.io.ObjectInputStream;
import java.io.ObjectOutputStream;
import java.rmi.RemoteException;
import javax.ejb.CreateException;
import javax.ejb.EJBException;
import javax.ejb.EJBObject;
import javax.ejb.Handle;
import javax.ejb.RemoveException;
import javax.ejb.SessionSynchronization;
import javax.naming.Context;
import javax.naming.InitialContext;
import org.apache.log4j.Category;
import org.jboss.test.cts.interfaces.BeanContextInfo;
import org.jboss.test.cts.interfaces.CtsCmpLocal;
import org.jboss.test.cts.interfaces.CtsCmpLocalHome;
import org.jboss.test.cts.interfaces.StatefulSession;
import org.jboss.test.cts.interfaces.StatefulSessionHome;
import org.jboss.test.cts.interfaces.StatelessSession;
import org.jboss.test.cts.interfaces.StatelessSessionHome;
import org.jboss.test.cts.keys.AccountPK;
import org.jboss.test.util.ejb.SessionSupport;
public class StatefulSessionBean
extends SessionSupport
implements SessionSynchronization
{
private static transient Category log = Category.getInstance(StatefulSessionBean.class);
private transient int counterAtTxStart;
private String testName;
private int counter;
public void ejbCreate(String testName)
{
this.testName = testName;
log = Category.getInstance(StatefulSessionBean.class.getName()+"#"+testName);
log.debug("ejbCreate("+testName+"), ctx="+sessionCtx);
}
public void afterBegin ()
{
log.debug("afterBegin()..., counter="+counter);
counterAtTxStart = counter;
}
public void afterCompletion (boolean isCommited)
{
log.debug("afterCompletion(), isCommited="+isCommited
+", counter="+counter+", counterAtTxStart="+counterAtTxStart);
if( isCommited == false )
{
counter = counterAtTxStart;
log.debug("Rolling counter back to: "+counter);
}
else
{
log.debug("Committed updated counter: "+counter);
}
}
public void beforeCompletion ()
{
log.debug("beforeCompletion(), counter="+counter
+", counterAtTxStart="+counterAtTxStart);
}
public void incCounter ()
{
counter++;
}
public void decCounter ()
{
counter--;
}
public int getCounter ()
{
return counter;
}
public void setCounter (int value)
{
counter = value;
}
public String txMandatoryMethod(String msg)
{
log.debug("txMandatoryMethod( ), msg="+msg);
return msg;
}
}