Search in sources :

Example 11 with AtomicTransaction

use of com.arjuna.ats.jts.extensions.AtomicTransaction in project narayana by jbosstm.

the class AITExplicitObjectImpl01 method tran_rollback_writelock.

public void tran_rollback_writelock(Control ctrl) throws InvocationException {
    try {
        com.arjuna.ats.jts.ExplicitInterposition interposition = new com.arjuna.ats.jts.ExplicitInterposition();
        interposition.registerTransaction(ctrl);
        AtomicTransaction atomicTransaction = new AtomicTransaction();
        try {
            atomicTransaction.begin();
            if (setlock(new Lock(LockMode.WRITE), 0) == LockResult.GRANTED) {
                atomicTransaction.rollback();
            } else {
                atomicTransaction.rollback();
                throw new InvocationException();
            }
        } catch (InvocationException invocationException) {
            interposition.unregisterTransaction();
            throw invocationException;
        } catch (Exception exception) {
            System.err.println("AITExplicitObjectImpl01.tran_rollback_writelock: " + exception);
            if (atomicTransaction.get_status() == Status.StatusActive) {
                atomicTransaction.rollback();
            }
            interposition.unregisterTransaction();
            throw new InvocationException();
        } catch (Error error) {
            System.err.println("AITExplicitObjectImpl01.tran_rollback_writelock: " + error);
            if (atomicTransaction.get_status() == Status.StatusActive) {
                atomicTransaction.rollback();
            }
            interposition.unregisterTransaction();
            throw new InvocationException();
        }
        interposition.unregisterTransaction();
    } catch (InvocationException invocationException) {
        throw invocationException;
    } catch (Exception exception) {
        System.err.println("AITExplicitObjectImpl01.tran_rollback_writelock: " + exception);
        throw new InvocationException();
    }
}
Also used : AtomicTransaction(com.arjuna.ats.jts.extensions.AtomicTransaction) Lock(com.arjuna.ats.txoj.Lock)

Example 12 with AtomicTransaction

use of com.arjuna.ats.jts.extensions.AtomicTransaction in project narayana by jbosstm.

the class Client_ImplicitObject_TranCommit_NoTranReadLock method main.

public static void main(String[] args) {
    try {
        ORBInterface.initORB(args, null);
        OAInterface.initOA();
        String prefix = args[args.length - 3];
        int numberOfCalls = Integer.parseInt(args[args.length - 2]);
        String implicitObjectIOR = ServerIORStore.loadIOR(args[args.length - 1]);
        ImplicitObject implicitObject = ImplicitObjectHelper.narrow(ORBInterface.orb().string_to_object(implicitObjectIOR));
        boolean correct = true;
        Date start = new Date();
        for (int index = 0; index < numberOfCalls; index++) {
            AtomicTransaction atomicTransaction = new AtomicTransaction();
            atomicTransaction.begin();
            implicitObject.no_tran_readlock();
            atomicTransaction.commit(true);
        }
        Date end = new Date();
        float operationDuration = ((float) (end.getTime() - start.getTime())) / ((float) numberOfCalls);
        System.err.println("Operation duration       : " + operationDuration + "ms");
        System.err.println("Test duration            : " + (end.getTime() - start.getTime()) + "ms");
        correct = PerformanceProfileStore.checkPerformance(prefix + "_ImplicitObject_TranCommit_NoTranReadLock", operationDuration);
        if (correct) {
            System.out.println("Passed");
        } else {
            System.out.println("Failed");
        }
    } catch (Exception exception) {
        System.out.println("Failed");
        System.err.println("Client_ImplicitObject_TranCommit_NoTranReadLock.main: " + exception);
        exception.printStackTrace(System.err);
    }
    try {
        OAInterface.shutdownOA();
        ORBInterface.shutdownORB();
    } catch (Exception exception) {
        System.err.println("Client_ImplicitObject_TranCommit_NoTranReadLock.main: " + exception);
        exception.printStackTrace(System.err);
    }
}
Also used : AtomicTransaction(com.arjuna.ats.jts.extensions.AtomicTransaction) Date(java.util.Date)

Example 13 with AtomicTransaction

use of com.arjuna.ats.jts.extensions.AtomicTransaction in project narayana by jbosstm.

the class Client_ImplicitObject_TranCommit_TranRollbackReadLock method main.

public static void main(String[] args) {
    try {
        ORBInterface.initORB(args, null);
        OAInterface.initOA();
        String prefix = args[args.length - 3];
        int numberOfCalls = Integer.parseInt(args[args.length - 2]);
        String implicitObjectIOR = ServerIORStore.loadIOR(args[args.length - 1]);
        ImplicitObject implicitObject = ImplicitObjectHelper.narrow(ORBInterface.orb().string_to_object(implicitObjectIOR));
        boolean correct = true;
        Date start = new Date();
        for (int index = 0; index < numberOfCalls; index++) {
            AtomicTransaction atomicTransaction = new AtomicTransaction();
            atomicTransaction.begin();
            implicitObject.tran_rollback_readlock();
            atomicTransaction.commit(true);
        }
        Date end = new Date();
        float operationDuration = ((float) (end.getTime() - start.getTime())) / ((float) numberOfCalls);
        System.err.println("Operation duration       : " + operationDuration + "ms");
        System.err.println("Test duration            : " + (end.getTime() - start.getTime()) + "ms");
        correct = PerformanceProfileStore.checkPerformance(prefix + "_ImplicitObject_TranCommit_TranRollbackReadLock", operationDuration);
        if (correct) {
            System.out.println("Passed");
        } else {
            System.out.println("Failed");
        }
    } catch (Exception exception) {
        System.out.println("Failed");
        System.err.println("Client_ImplicitObject_TranCommit_TranRollbackReadLock.main: " + exception);
        exception.printStackTrace(System.err);
    }
    try {
        OAInterface.shutdownOA();
        ORBInterface.shutdownORB();
    } catch (Exception exception) {
        System.err.println("Client_ImplicitObject_TranCommit_TranRollbackReadLock.main: " + exception);
        exception.printStackTrace(System.err);
    }
}
Also used : AtomicTransaction(com.arjuna.ats.jts.extensions.AtomicTransaction) Date(java.util.Date)

Example 14 with AtomicTransaction

use of com.arjuna.ats.jts.extensions.AtomicTransaction in project narayana by jbosstm.

the class Client_ImplicitObject_TranRollback_NoTranWriteLock method main.

public static void main(String[] args) {
    try {
        ORBInterface.initORB(args, null);
        OAInterface.initOA();
        String prefix = args[args.length - 3];
        int numberOfCalls = Integer.parseInt(args[args.length - 2]);
        String implicitObjectIOR = ServerIORStore.loadIOR(args[args.length - 1]);
        ImplicitObject implicitObject = ImplicitObjectHelper.narrow(ORBInterface.orb().string_to_object(implicitObjectIOR));
        boolean correct = true;
        Date start = new Date();
        for (int index = 0; index < numberOfCalls; index++) {
            AtomicTransaction atomicTransaction = new AtomicTransaction();
            atomicTransaction.begin();
            implicitObject.no_tran_writelock();
            atomicTransaction.rollback();
        }
        Date end = new Date();
        float operationDuration = ((float) (end.getTime() - start.getTime())) / ((float) numberOfCalls);
        System.err.println("Operation duration       : " + operationDuration + "ms");
        System.err.println("Test duration            : " + (end.getTime() - start.getTime()) + "ms");
        correct = PerformanceProfileStore.checkPerformance(prefix + "_ImplicitObject_TranRollback_NoTranWriteLock", operationDuration);
        if (correct) {
            System.out.println("Passed");
        } else {
            System.out.println("Failed");
        }
    } catch (Exception exception) {
        System.out.println("Failed");
        System.err.println("Client_ImplicitObject_TranRollback_NoTranWriteLock.main: " + exception);
        exception.printStackTrace(System.err);
    }
    try {
        OAInterface.shutdownOA();
        ORBInterface.shutdownORB();
    } catch (Exception exception) {
        System.err.println("Client_ImplicitObject_TranRollback_NoTranWriteLock.main: " + exception);
        exception.printStackTrace(System.err);
    }
}
Also used : AtomicTransaction(com.arjuna.ats.jts.extensions.AtomicTransaction) Date(java.util.Date)

Example 15 with AtomicTransaction

use of com.arjuna.ats.jts.extensions.AtomicTransaction in project narayana by jbosstm.

the class Client_ImplicitObject_TranRollback_TranCommitReadLock method main.

public static void main(String[] args) {
    try {
        ORBInterface.initORB(args, null);
        OAInterface.initOA();
        String prefix = args[args.length - 3];
        int numberOfCalls = Integer.parseInt(args[args.length - 2]);
        String implicitObjectIOR = ServerIORStore.loadIOR(args[args.length - 1]);
        ImplicitObject implicitObject = ImplicitObjectHelper.narrow(ORBInterface.orb().string_to_object(implicitObjectIOR));
        boolean correct = true;
        Date start = new Date();
        for (int index = 0; index < numberOfCalls; index++) {
            AtomicTransaction atomicTransaction = new AtomicTransaction();
            atomicTransaction.begin();
            implicitObject.tran_commit_readlock();
            atomicTransaction.rollback();
        }
        Date end = new Date();
        float operationDuration = ((float) (end.getTime() - start.getTime())) / ((float) numberOfCalls);
        System.err.println("Operation duration       : " + operationDuration + "ms");
        System.err.println("Test duration            : " + (end.getTime() - start.getTime()) + "ms");
        correct = PerformanceProfileStore.checkPerformance(prefix + "_ImplicitObject_TranRollback_TranCommitReadLock", operationDuration);
        if (correct) {
            System.out.println("Passed");
        } else {
            System.out.println("Failed");
        }
    } catch (Exception exception) {
        System.out.println("Failed");
        System.err.println("Client_ImplicitObject_TranRollback_TranCommitReadLock.main: " + exception);
        exception.printStackTrace(System.err);
    }
    try {
        OAInterface.shutdownOA();
        ORBInterface.shutdownORB();
    } catch (Exception exception) {
        System.err.println("Client_ImplicitObject_TranRollback_TranCommitReadLock.main: " + exception);
        exception.printStackTrace(System.err);
    }
}
Also used : AtomicTransaction(com.arjuna.ats.jts.extensions.AtomicTransaction) Date(java.util.Date)

Aggregations

AtomicTransaction (com.arjuna.ats.jts.extensions.AtomicTransaction)101 Lock (com.arjuna.ats.txoj.Lock)38 Date (java.util.Date)36 IntHolder (org.omg.CORBA.IntHolder)12 JVMStats (org.jboss.jbossts.qa.Utils.JVMStats)9 Test (org.junit.Test)7 IOException (java.io.IOException)6 SystemException (org.omg.CORBA.SystemException)6 DemoResource (com.hp.mwtests.ts.jts.orbspecific.resources.DemoResource)3 ExplicitInterposition (com.arjuna.ats.jts.ExplicitInterposition)2 TopLevelTransaction (com.arjuna.ats.jts.extensions.TopLevelTransaction)2 Control (org.omg.CosTransactions.Control)2 DemoSubTranResource (com.hp.mwtests.ts.jts.orbspecific.resources.DemoSubTranResource)1 com.hp.mwtests.ts.jts.orbspecific.resources.demosync (com.hp.mwtests.ts.jts.orbspecific.resources.demosync)1 TRANSACTION_ROLLEDBACK (org.omg.CORBA.TRANSACTION_ROLLEDBACK)1