Package org.jboss.narayana.blacktie.jatmibroker.tx

Source Code of org.jboss.narayana.blacktie.jatmibroker.tx.TestRollbackOnly

/*
* JBoss, Home of Professional Open Source
* Copyright 2008, Red Hat, Inc., and others contributors as indicated
* by the @authors tag. All rights reserved.
* See the copyright.txt in the distribution for a
* full listing of individual contributors.
* This copyrighted material is made available to anyone wishing to use,
* modify, copy, or redistribute it subject to the terms and conditions
* of the GNU Lesser General Public License, v. 2.1.
* This program is distributed in the hope that it will be useful, but WITHOUT A
* WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A
* PARTICULAR PURPOSE.  See the GNU Lesser General Public License for more details.
* You should have received a copy of the GNU Lesser General Public License,
* v.2.1 along with this distribution; if not, write to the Free Software
* Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston,
* MA  02110-1301, USA.
*/
package org.jboss.narayana.blacktie.jatmibroker.tx;

import junit.framework.TestCase;

import org.apache.log4j.LogManager;
import org.apache.log4j.Logger;
import org.jboss.narayana.blacktie.jatmibroker.tx.TX;
import org.jboss.narayana.blacktie.jatmibroker.tx.TXINFO;
import org.jboss.narayana.blacktie.jatmibroker.tx.TestRollbackOnly;
import org.jboss.narayana.blacktie.jatmibroker.RunServer;
import org.jboss.narayana.blacktie.jatmibroker.core.conf.ConfigurationException;
import org.jboss.narayana.blacktie.jatmibroker.xatmi.Buffer;
import org.jboss.narayana.blacktie.jatmibroker.xatmi.Connection;
import org.jboss.narayana.blacktie.jatmibroker.xatmi.ConnectionException;
import org.jboss.narayana.blacktie.jatmibroker.xatmi.ConnectionFactory;
import org.jboss.narayana.blacktie.jatmibroker.xatmi.ResponseException;
import org.jboss.narayana.blacktie.jatmibroker.xatmi.Session;
import org.jboss.narayana.blacktie.jatmibroker.xatmi.TestTPConversation;
import org.jboss.narayana.blacktie.jatmibroker.xatmi.X_OCTET;

public class TestRollbackOnly extends TestCase {
  private static final Logger log = LogManager
      .getLogger(TestRollbackOnly.class);
  private RunServer server = new RunServer();
  private Connection connection;
  private int sendlen;
  private X_OCTET sendbuf;

  public void setUp() throws ConnectionException, ConfigurationException {
    server.serverinit();

    ConnectionFactory connectionFactory = ConnectionFactory
        .getConnectionFactory();
    connection = connectionFactory.getConnection();

    sendlen = "TestRbkOnly".length() + 1;
    sendbuf = (X_OCTET) connection.tpalloc("X_OCTET", null, sendlen);
    sendbuf.setByteArray("TestRbkOnly".getBytes());
  }

  public void tearDown() throws ConnectionException, ConfigurationException {
    connection.close();
    server.serverdone();
  }

  public void test_tpcall_TPETIME() throws ConnectionException {
    log.info("test_tpcall_TPETIME");
    server.tpadvertiseTestRollbackOnlyTpcallTPETIMEService();
    assertTrue(TX.tx_open() == TX.TX_OK);
    assertTrue(TX.tx_begin() == TX.TX_OK);

    try {
      connection.tpcall(RunServer.getServiceNameTestRollbackOnly(),
          sendbuf, 0);
      fail("Expected e.getTperrno() == Connection.TPETIME");
    } catch (ConnectionException e) {
      assertTrue(e.getTperrno() == Connection.TPETIME);
    }

    TXINFO txinfo = new TXINFO();
    int inTx = TX.tx_info(txinfo);
    log.info("inTx=" + inTx);
    assertTrue(txinfo.transaction_state == TX.TX_ROLLBACK_ONLY);
    assertTrue(TX.tx_commit() == TX.TX_ROLLBACK);
  }

  public void x_test_tpcall_TPEOTYPE() throws ConnectionException {
    log.info("test_tpcall_TPETIME");
    server.tpadvertiseTestTpcallTPEOTYPEService();

    assertTrue(TX.tx_open() == TX.TX_OK);
    assertTrue(TX.tx_begin() == TX.TX_OK);

    try {
      connection.tpcall(RunServer.getServiceNameTestRollbackOnly(),
          sendbuf, Connection.TPNOCHANGE);
      fail("Expected e.getTperrno() == TPEOTYPE");
    } catch (ConnectionException e) {
      assertTrue(e.getTperrno() == Connection.TPEOTYPE);
    }

    TXINFO txinfo = new TXINFO();
    int inTx = TX.tx_info(txinfo);
    log.info("inTx=" + inTx);
    assertTrue(txinfo.transaction_state == TX.TX_ROLLBACK_ONLY);
    assertTrue(TX.tx_commit() == TX.TX_ROLLBACK);
  }

  public void test_tpcall_TPESVCFAIL() throws ConnectionException {
    log.info("test_tpcall_TPESVCFAIL");
    server.tpadvertiseTestRollbackOnlyTpcallTPESVCFAILService();

    assertTrue(TX.tx_open() == TX.TX_OK);
    assertTrue(TX.tx_begin() == TX.TX_OK);

    try {
      connection.tpcall(RunServer.getServiceNameTestRollbackOnly(),
          sendbuf, 0);
      fail("Expected e.getTperrno() == TPESVCFAIL");
    } catch (ResponseException e) {
      assertTrue(TestTPConversation.strcmp(e.getReceived(),
          "test_tpcall_TPESVCFAIL_service") == 0);
      assertTrue(e.getTperrno() == Connection.TPESVCFAIL);
    } catch (ConnectionException e) {
      fail("Expected e.getTperrno() == TPESVCFAIL");
    }

    TXINFO txinfo = new TXINFO();
    int inTx = TX.tx_info(txinfo);
    log.info("inTx=" + inTx);
    assertTrue(txinfo.transaction_state == TX.TX_ROLLBACK_ONLY);
    assertTrue(TX.tx_commit() == TX.TX_ROLLBACK);
  }

  public void test_tprecv_TPEV_DISCONIMM() throws ConnectionException {
    log.info("test_tprecv_TPEV_DISCONIMM");
    server.tpadvertiseTestRollbackOnlyTprecvTPEVDISCONIMMService();

    assertTrue(TX.tx_open() == TX.TX_OK);
    assertTrue(TX.tx_begin() == TX.TX_OK);

    Session cd = connection.tpconnect(
        RunServer.getServiceNameTestRollbackOnly2(), sendbuf,
        Connection.TPSENDONLY);
    cd.tpdiscon();

    TXINFO txinfo = new TXINFO();
    int inTx = TX.tx_info(txinfo);
    log.info("inTx=" + inTx);
    assertTrue(txinfo.transaction_state == TX.TX_ROLLBACK_ONLY);
    assertTrue(TX.tx_commit() == TX.TX_ROLLBACK);
  }

  public void test_tprecv_TPEV_SVCFAIL() throws ConnectionException {
    log.info("test_tprecv_TPEV_SVCFAIL");
    server.tpadvertiseTestRollbackOnlyTprecvTPEVSVCFAILService();

    assertTrue(TX.tx_open() == TX.TX_OK);
    assertTrue(TX.tx_begin() == TX.TX_OK);

    Session cd = connection.tpconnect(
        RunServer.getServiceNameTestRollbackOnly2(), sendbuf,
        Connection.TPRECVONLY);

    try {
      cd.tprecv(0);
      fail("Expected e.getEvent() == Connection.TPEV_SVCFAIL");
    } catch (ResponseException e) {
      assertTrue(e.getEvent() == Connection.TPEV_SVCFAIL);
      assertTrue(e.getTperrno() == Connection.TPEEVENT);
      Buffer rcvbuf = e.getReceived();
      assertTrue(TestTPConversation.strcmp(rcvbuf,
          "test_tprecv_TPEV_SVCFAIL_service") == 0);
    } catch (ConnectionException e) {
      fail("Expected e.getEvent() == Connection.TPEV_SVCFAIL");
    }

    TXINFO txinfo = new TXINFO();
    int inTx = TX.tx_info(txinfo);
    log.info("inTx=" + inTx);
    assertTrue(txinfo.transaction_state == TX.TX_ROLLBACK_ONLY);
    assertTrue(TX.tx_commit() == TX.TX_ROLLBACK);
  }

  public void test_no_tpreturn() throws ConnectionException {
    log.info("test_no_tpreturn");
    server.tpadvertiseTestRollbackOnlyNoTpreturnService();

    assertTrue(TX.tx_open() == TX.TX_OK);
    assertTrue(TX.tx_begin() == TX.TX_OK);

    try {
      connection.tpcall(RunServer.getServiceNameTestRollbackOnly(),
          sendbuf, 0);
      fail("Expected e.getTperrno() == Connection.TPESVCERR");
    } catch (ConnectionException e) {
      assertTrue(e.getTperrno() == Connection.TPESVCERR);
    }

    TXINFO txinfo = new TXINFO();
    int inTx = TX.tx_info(txinfo);
    log.info("inTx=" + inTx);
    assertTrue(txinfo.transaction_state == TX.TX_ROLLBACK_ONLY);
    assertTrue(TX.tx_commit() == TX.TX_ROLLBACK);
  }
}
TOP

Related Classes of org.jboss.narayana.blacktie.jatmibroker.tx.TestRollbackOnly

TOP
Copyright © 2018 www.massapi.com. All rights reserved.
All source code are property of their respective owners. Java is a trademark of Sun Microsystems, Inc and owned by ORACLE Inc. Contact coftware#gmail.com.