Package org.jboss.messaging.core.plugin.contract

Examples of org.jboss.messaging.core.plugin.contract.MessageStore


     
         TransactionManager tm = getTransactionManagerReference();
        
         ServerPeer serverPeer = (ServerPeer)server.getAttribute(serverPeerObjectName, "Instance");
        
         MessageStore ms = serverPeer.getMessageStore();
        
         PersistenceManager pm = serverPeer.getPersistenceManagerInstance();
        
         TransactionRepository tr = serverPeer.getTxRepository();
        


      try
      {
         TransactionManager tm = getTransactionManagerReference();

         ServerPeer serverPeer = (ServerPeer)server.getAttribute(serverPeerObjectName, "Instance");
         MessageStore ms = serverPeer.getMessageStore();
         TransactionRepository tr = serverPeer.getTxRepository();
         PersistenceManager pm = serverPeer.getPersistenceManagerInstance();
         int nodeId = serverPeer.getServerPeerID();

         Class clazz = Class.forName(messagePullPolicy);

   // Public --------------------------------------------------------
  
   public void testAutoAck1() throws Exception
   {
      MessageStore store = ServerManagement.getMessageStore();
     
      Connection conn = cf.createConnection();
     
      Session sess = conn.createSession(false, Session.AUTO_ACKNOWLEDGE);
     
      MessageProducer prod = sess.createProducer(queue);
     
      MessageConsumer cons = sess.createConsumer(queue);
     
      conn.start();
     
      TextMessage m = sess.createTextMessage("wibble");
     
      prod.send(m);
 
      TextMessage m2 = (TextMessage)cons.receive();
      
      assertNotNull(m2);
      assertEquals(m.getText(), m2.getText());
     
      MessageReference ref = store.reference(((MessageProxy)m2).getMessage().getMessageID());
     
      assertNull(ref);
     
      conn.close();
   }

      conn.close();
   }
  
   public void testAutoAck2() throws Exception
   {
      MessageStore store = ServerManagement.getMessageStore();
     
      Connection conn = cf.createConnection();
     
      Session sess = conn.createSession(false, Session.AUTO_ACKNOWLEDGE);
     
      MessageProducer prod = sess.createProducer(queue);
                 
      conn.start();
     
      TextMessage m = sess.createTextMessage("wibble");
     
      prod.send(m);
     
      Thread.sleep(1000);
     
      MessageConsumer cons = sess.createConsumer(queue);
     
      TextMessage m2 = (TextMessage)cons.receive(1000);
     
     
      assertNotNull(m2);
     
      assertEquals(m.getText(), m2.getText());
     
      MessageReference ref = store.reference(((MessageProxy)m2).getMessage().getMessageID());
     
      assertNull(ref);
     
      conn.close();
   }

      conn.close();
   }
  
   public void testClientAck1() throws Exception
   {
      MessageStore store = ServerManagement.getMessageStore();
     
      Connection conn = cf.createConnection();
     
      Session sess = conn.createSession(false, Session.CLIENT_ACKNOWLEDGE);
     
      MessageProducer prod = sess.createProducer(queue);
     
      MessageConsumer cons = sess.createConsumer(queue);
     
      conn.start();
     
      TextMessage m = sess.createTextMessage("wibble");
     
      prod.send(m);
     
      TextMessage m2 = (TextMessage)cons.receive(1000);
     
      assertNotNull(m2);
      assertEquals(m.getText(), m2.getText());
     
      MessageReference ref = store.reference(((MessageProxy)m2).getMessage().getMessageID());
     
      assertEquals(((MessageProxy)m).getMessage().getMessageID(), ref.getMessage().getMessageID());
     
      ref.releaseMemoryReference();
         
      m2.acknowledge();
     
      ref = store.reference(((MessageProxy)m2).getMessage().getMessageID());
     
      assertNull(ref);
     
      conn.close();
   }

      conn.close();
   }
  
   public void testClientAck2() throws Exception
   {
      MessageStore store = ServerManagement.getMessageStore();
     
      Connection conn = cf.createConnection();
     
      Session sess = conn.createSession(false, Session.CLIENT_ACKNOWLEDGE);
     
      MessageProducer prod = sess.createProducer(queue);
                 
      conn.start();
     
      TextMessage m = sess.createTextMessage("wibble");
     
      prod.send(m);
     
      Thread.sleep(1000);
     
      MessageConsumer cons = sess.createConsumer(queue);
     
      TextMessage m2 = (TextMessage)cons.receive(1000);
     
      assertNotNull(m2);
      assertEquals(m.getText(), m2.getText());
     
      MessageReference ref = store.reference(((MessageProxy)m2).getMessage().getMessageID());
     
      assertEquals(((MessageProxy)m).getMessage().getMessageID(), ref.getMessage().getMessageID());
     
      ref.releaseMemoryReference();
     
      m2.acknowledge();
     
      ref = store.reference(((MessageProxy)m2).getMessage().getMessageID());
     
      assertNull(ref);
     
      conn.close();
   }

      conn.close();
   }
  
   public void testRedelivery() throws Exception
   {
      MessageStore store = ServerManagement.getMessageStore();
     
      Connection conn = cf.createConnection();
     
      Session sess = conn.createSession(false, Session.CLIENT_ACKNOWLEDGE);
     
      MessageProducer prod = sess.createProducer(queue);
                 
      conn.start();
     
      TextMessage m = sess.createTextMessage("wibble");
     
      prod.send(m);
     
      Thread.sleep(1000);
     
      MessageConsumer cons = sess.createConsumer(queue);
     
      TextMessage m2 = (TextMessage)cons.receive(1000);
     
      assertNotNull(m2);
      assertEquals(m.getText(), m2.getText());
     
      MessageReference ref = store.reference(((MessageProxy)m2).getMessage().getMessageID());
     
      assertEquals(((MessageProxy)m).getMessage().getMessageID(), ref.getMessage().getMessageID());
     
      ref.releaseMemoryReference();
     
      sess.recover();
     
      TextMessage m3 = (TextMessage)cons.receive();
     
      assertNotNull(m3);
      assertEquals(m.getText(), m3.getText());
     
      ref = store.reference(((MessageProxy)m2).getMessage().getMessageID());
     
      assertEquals(((MessageProxy)m).getMessage().getMessageID(), ref.getMessage().getMessageID());
     
      ref.releaseMemoryReference();
           
      m2.acknowledge();
     
      ref = store.reference(((MessageProxy)m2).getMessage().getMessageID());
     
      assertNull(ref);
     
      conn.close();
   }

      conn.close();
   }
  
   public void testTransactionCommit() throws Exception
   {
      MessageStore store = ServerManagement.getMessageStore();
     
      Connection conn = cf.createConnection();
     
      Session sess = conn.createSession(true, Session.SESSION_TRANSACTED);
     
      MessageProducer prod = sess.createProducer(queue);
     
      MessageConsumer cons = sess.createConsumer(queue);
                       
      conn.start();
     
      TextMessage m = sess.createTextMessage("wibble");
     
      prod.send(m);
      sess.commit();
     
      TextMessage m2 = (TextMessage)cons.receive(1000);
     
      assertNotNull(m2);
      assertEquals(m.getText(), m2.getText());
     
      SimpleMessageReference ref = (SimpleMessageReference)store.reference(((MessageProxy)m2).getMessage().getMessageID());
     
      assertEquals(2, ref.getInMemoryChannelCount());
     
      assertEquals(((MessageProxy)m).getMessage().getMessageID(), ref.getMessage().getMessageID());
     
      ref.releaseMemoryReference();
     
      sess.commit();
     
      ref = (SimpleMessageReference)store.reference(((MessageProxy)m2).getMessage().getMessageID());
      assertNull(ref);
     
      conn.close();
   }

      conn.close();
   }
  
   public void testTransactionRollback() throws Exception
   {
      MessageStore store = ServerManagement.getMessageStore();
     
      Connection conn = cf.createConnection();
     
      Session sess = conn.createSession(true, Session.SESSION_TRANSACTED);
     
      MessageProducer prod = sess.createProducer(queue);
     
      MessageConsumer cons = sess.createConsumer(queue);
                       
      conn.start();
     
      TextMessage m = sess.createTextMessage("wibble");
     
      prod.send(m);
      sess.commit();
     
      TextMessage m2 = (TextMessage)cons.receive(1000);
     
      assertNotNull(m2);
      assertEquals(m.getText(), m2.getText());
     
      MessageReference ref = store.reference(((MessageProxy)m2).getMessage().getMessageID());
      assertEquals(((MessageProxy)m).getMessage().getMessageID(), ref.getMessage().getMessageID());
     
      ref.releaseMemoryReference();
     
      sess.rollback();
     
      TextMessage m3 = (TextMessage)cons.receive();
     
      assertNotNull(m3);
      assertEquals(m.getText(), m3.getText());
     
      ref = store.reference(((MessageProxy)m3).getMessage().getMessageID());
      assertEquals(((MessageProxy)m).getMessage().getMessageID(), ref.getMessage().getMessageID());
     
      ref.releaseMemoryReference();
     
      sess.commit();
     
      ref = store.reference(((MessageProxy)m2).getMessage().getMessageID());
      assertNull(ref);
     
      conn.close();
   }

      conn.close();
   }
  
   public void cancelTest() throws Exception
   {
      MessageStore store = ServerManagement.getMessageStore();
     
      Connection conn = cf.createConnection();
     
      Session sess = conn.createSession(false, Session.CLIENT_ACKNOWLEDGE);
     
      MessageProducer prod = sess.createProducer(queue);
     
      MessageConsumer cons = sess.createConsumer(queue);
     
      conn.start();
     
      TextMessage m1 = sess.createTextMessage("wibble");
      TextMessage m2 = sess.createTextMessage("wibble");
     
      prod.send(m1);
      prod.send(m2);
     
      TextMessage m3 = (TextMessage)cons.receive(1000);
     
      assertNotNull(m3);
      assertEquals(m1.getText(), m3.getText());
     
      TextMessage m4 = (TextMessage)cons.receive();
     
      assertNotNull(m4);
      assertEquals(m1.getText(), m4.getText());
     
      sess.recover();
     
      TextMessage m5 = (TextMessage)cons.receive();
     
      assertNotNull(m5);
      assertEquals(m1.getText(), m5.getText());
     
      TextMessage m6 = (TextMessage)cons.receive();
     
      assertNotNull(m6);
      assertEquals(m1.getText(), m6.getText());
     
      m6.acknowledge();
     
      MessageReference ref = store.reference(((MessageProxy)m2).getMessage().getMessageID());
     
      assertNull(ref);
     
      conn.close();
   }

TOP

Related Classes of org.jboss.messaging.core.plugin.contract.MessageStore

Copyright © 2018 www.massapicom. 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.