Package org.apache.sandesha2

Source Code of org.apache.sandesha2.SandeshaReportsTest

/*
* Copyright 2004,2005 The Apache Software Foundation.
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
*      http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/

package org.apache.sandesha2;

import java.io.File;
import java.util.ArrayList;
import java.util.Iterator;
import java.util.List;

import org.apache.axis2.AxisFault;
import org.apache.axis2.Constants;
import org.apache.axis2.addressing.EndpointReference;
import org.apache.axis2.client.Options;
import org.apache.axis2.client.ServiceClient;
import org.apache.axis2.context.ConfigurationContext;
import org.apache.axis2.context.ConfigurationContextFactory;
import org.apache.sandesha2.client.SandeshaClient;
import org.apache.sandesha2.client.SandeshaClientConstants;
import org.apache.sandesha2.client.SandeshaReport;
import org.apache.sandesha2.client.SequenceReport;
import org.apache.sandesha2.util.SandeshaUtil;

public class SandeshaReportsTest extends SandeshaTestCase {

  private boolean startedServer = false;

  public SandeshaReportsTest () {
    super ("SandeshaReportsTest");
  }
 
  public void setUp () throws Exception {
    super.setUp();

    String repoPath = "target" + File.separator + "repos" + File.separator + "server";
    String axis2_xml = "target" + File.separator + "repos" + File.separator + "server" + File.separator + "server_axis2.xml";

    if (!startedServer)
      startServer(repoPath, axis2_xml);
    startedServer = true;
  }
 
  /**
   * Override the teardown processing
   */
  public void tearDown () throws Exception {
    super.tearDown();
  }
 
  public void testSequenceReports () throws Exception  {

    String to = "http://127.0.0.1:" + serverPort + "/axis2/services/RMSampleService";
   
    String repoPath = "target" + File.separator + "repos" + File.separator + "client";
    String axis2_xml = "target" + File.separator + "repos" + File.separator + "client" + File.separator + "client_axis2.xml";
   
    ConfigurationContext configContext = ConfigurationContextFactory.createConfigurationContextFromFileSystem(repoPath,axis2_xml);

    Options clientOptions = new Options ();
    clientOptions.setAction(echoAction);
    clientOptions.setTo(new EndpointReference (to));
   
    String sequenceKey = SandeshaUtil.getUUID();
    clientOptions.setProperty(SandeshaClientConstants.SEQUENCE_KEY,sequenceKey);
   
    ServiceClient serviceClient = new ServiceClient (configContext,null);
    String acksTo = serviceClient.getMyEPR(Constants.TRANSPORT_HTTP).getAddress();
    clientOptions.setProperty(SandeshaClientConstants.AcksTo,acksTo);
   
    clientOptions.setTransportInProtocol(Constants.TRANSPORT_HTTP);
   

    serviceClient.setOptions(clientOptions);
    //serviceClient.
   
    clientOptions.setTransportInProtocol(Constants.TRANSPORT_HTTP);
    clientOptions.setUseSeparateListener(true);
   
    serviceClient.setOptions(clientOptions);
   
    TestCallback callback1 = new TestCallback ("Callback 1");
    serviceClient.sendReceiveNonBlocking(getEchoOMBlock("echo1",sequenceKey),callback1);
   
    TestCallback callback2 = new TestCallback ("Callback 2");
    serviceClient.sendReceiveNonBlocking (getEchoOMBlock("echo2",sequenceKey),callback2);

    long limit = System.currentTimeMillis() + waitTime;
    Error lastError = null;
    while(System.currentTimeMillis() < limit) {
      Thread.sleep(tickTime); // Try the assertions each tick interval, until they pass or we time out
     
      try {
            //testing outgoing sequence reports
        SequenceReport sequenceReport = SandeshaClient.getOutgoingSequenceReport(serviceClient);
        assertTrue(sequenceReport.getCompletedMessages().contains(new Long(1)));
        assertTrue(sequenceReport.getCompletedMessages().contains(new Long(2)));
        assertEquals(sequenceReport.getSequenceStatus(),SequenceReport.SEQUENCE_STATUS_ESTABLISHED);
        assertEquals(sequenceReport.getSequenceDirection(),SequenceReport.SEQUENCE_DIRECTION_OUT);
       
        //testing incoming sequence reports
        List incomingSequenceReports = SandeshaClient.getIncomingSequenceReports(configContext);
        assertEquals(incomingSequenceReports.size(),1);
        SequenceReport incomingSequenceReport = (SequenceReport) incomingSequenceReports.get(0);
        assertEquals(incomingSequenceReport.getCompletedMessages().size(),2);
        assertNotNull(incomingSequenceReport.getSequenceID());
        assertEquals(incomingSequenceReport.getSequenceDirection(),SequenceReport.SEQUENCE_DIRECTION_IN);
        assertNotNull(incomingSequenceReport.getInternalSequenceID());
       
        assertEquals(incomingSequenceReport.getSequenceID(),incomingSequenceReport.getInternalSequenceID())//for the incoming side, internalSequenceID==sequenceID

        lastError = null;
        break;
      } catch(Error e) {
        lastError = e;
      }
    }
    if(lastError != null) throw lastError;

    SandeshaClient.terminateSequence(serviceClient, sequenceKey);
    SandeshaClient.waitUntilSequenceCompleted(serviceClient, sequenceKey);
   
    SequenceReport sequenceReport = SandeshaClient.getOutgoingSequenceReport(serviceClient);
    assertEquals(sequenceReport.getSequenceStatus(),SequenceReport.SEQUENCE_STATUS_TERMINATED);
   
    configContext.getListenerManager().stop();
    serviceClient.cleanup();
  }
 
  public void testRMReport () throws AxisFault,InterruptedException {
   
    String to = "http://127.0.0.1:" + serverPort + "/axis2/services/RMSampleService";
   
    String repoPath = "target" + File.separator + "repos" + File.separator + "client";
    String axis2_xml = "target" + File.separator + "repos" + File.separator + "client" + File.separator + "client_axis2.xml";

    ConfigurationContext configContext = ConfigurationContextFactory.createConfigurationContextFromFileSystem(repoPath,axis2_xml);

    //clientOptions.setSoapVersionURI(SOAP12Constants.SOAP_ENVELOPE_NAMESPACE_URI);
    Options clientOptions = new Options ();
    clientOptions.setAction(pingAction);
//    clientOptions.setSoapVersionURI(SOAP11Constants.SOAP_ENVELOPE_NAMESPACE_URI);
   
    clientOptions.setTo(new EndpointReference (to));
   
    String sequenceKey1 = "sequence3";
    clientOptions.setProperty(SandeshaClientConstants.SEQUENCE_KEY,sequenceKey1);
   
    ServiceClient serviceClient = new ServiceClient (configContext,null);
   
    serviceClient.setOptions(clientOptions);
   
   
    serviceClient.fireAndForget(getPingOMBlock("ping1"));   
    clientOptions.setProperty(SandeshaClientConstants.LAST_MESSAGE, "true");
    serviceClient.fireAndForget(getPingOMBlock("ping2"));
   
    String sequenceKey2 = "sequence4";
    clientOptions.setProperty(SandeshaClientConstants.SEQUENCE_KEY,sequenceKey2);
   
    clientOptions.setProperty(SandeshaClientConstants.LAST_MESSAGE, "false");
    serviceClient.fireAndForget(getPingOMBlock("ping1"));   
   
    long limit = System.currentTimeMillis() + waitTime;
    Error lastError = null;
    while(System.currentTimeMillis() < limit) {
      Thread.sleep(tickTime); // Try the assertions each tick interval, until they pass or we time out
     
      try {
        SandeshaReport rmReport = SandeshaClient.getSandeshaReport(configContext);
       
         SequenceReport sequence1Report = null;
         SequenceReport sequence2Report = null;
        
         Iterator iterator = rmReport.getOutgoingSequenceList().iterator();
         while (iterator.hasNext()) {
           String sequenceID = (String) iterator.next();
          
            String internalSequenceID = rmReport.getInternalSequenceIdOfOutSequence(sequenceID);
           
            if (internalSequenceID.indexOf(sequenceKey1)>=0) {
              sequence1Report = SandeshaClient.getOutgoingSequenceReport(to,sequenceKey1,configContext);
            } else if (internalSequenceID.indexOf(sequenceKey2)>=0){
              sequence2Report = SandeshaClient.getOutgoingSequenceReport(to,sequenceKey2,configContext);
            }
         }
        
         assertNotNull(sequence1Report);
         assertNotNull(sequence2Report);
        
         assertEquals(sequence1Report.getCompletedMessages().size(),2);
         assertEquals(sequence2Report.getCompletedMessages().size(),1);
        
         assertEquals(sequence1Report.getSequenceStatus(),SequenceReport.SEQUENCE_STATUS_TERMINATED);
         assertEquals(sequence2Report.getSequenceStatus(),SequenceReport.SEQUENCE_STATUS_ESTABLISHED)

        lastError = null;
        break;
      } catch(Error e) {
        lastError = e;
      }
    }
    if(lastError != null) throw lastError;
 
    configContext.getListenerManager().stop();
    serviceClient.cleanup();
  }
 
 
//  public void testSequenceTermination () throws AxisFault,InterruptedException {
//   
//    String to = "http://127.0.0.1:8060/axis2/services/RMSampleService";
//    String transportTo = "http://127.0.0.1:8060/axis2/services/RMSampleService";
//   
//    String repoPath = "target" + File.separator + "repos" + File.separator + "client";
//    String axis2_xml = "target" + File.separator + "repos" + File.separator + "client" + File.separator + "client_axis2.xml";
//
//    ConfigurationContext configContext = ConfigurationContextFactory.createConfigurationContextFromFileSystem(repoPath,axis2_xml);
//
//    //clientOptions.setSoapVersionURI(SOAP12Constants.SOAP_ENVELOPE_NAMESPACE_URI);
//    Options clientOptions = new Options ();
//    clientOptions.setProperty(Options.COPY_PROPERTIES,new Boolean (true));
//    clientOptions.setSoapVersionURI(SOAP11Constants.SOAP_ENVELOPE_NAMESPACE_URI);
//   
//    clientOptions.setTo(new EndpointReference (to));
//    clientOptions.setProperty(MessageContextConstants.TRANSPORT_URL,transportTo);
//   
//    String sequenceKey1 = "sequence1";
//    clientOptions.setProperty(SandeshaClientConstants.SEQUENCE_KEY,sequenceKey1);
//   
//    ServiceClient serviceClient = new ServiceClient (configContext,null);
//   
//    serviceClient.setOptions(clientOptions);
//   
//    serviceClient.fireAndForget(getPingOMBlock("ping11"));   
//    serviceClient.fireAndForget(getPingOMBlock("ping12"));
//   
//    String sequenceKey2 = "sequence2";
//    clientOptions.setProperty(SandeshaClientConstants.SEQUENCE_KEY,sequenceKey2);
//   
//    serviceClient.fireAndForget(getPingOMBlock("ping21")); 
//   
//    SandeshaClient.terminateSequence(serviceClient,sequenceKey1);
//   
//    clientOptions.setProperty(SandeshaClientConstants.LAST_MESSAGE, "true");
//    serviceClient.fireAndForget(getPingOMBlock("ping22")); 
//    try {
//      //waiting till the messages exchange finishes.
//      Thread.sleep(10000);
//    } catch (InterruptedException e) {
//      throw new SandeshaException ("sleep interupted");
//    }
//   
//   
//    SandeshaReport rmReport = SandeshaClient.getSandeshaReport(configContext);
//   
//     SequenceReport sequence1Report = null;
//     SequenceReport sequence2Report = null;
//    
//     Iterator iterator = rmReport.getOutgoingSequenceList().iterator();
//     while (iterator.hasNext()) {
//       String sequenceID = (String) iterator.next();
//      
//        String internalSequenceID = rmReport.getInternalSequenceIdOfOutSequence(sequenceID);
//       
//        if (internalSequenceID.indexOf(sequenceKey1)>=0) {
//          sequence1Report = SandeshaClient.getOutgoingSequenceReport(to,sequenceKey1,configContext);
//        } else if (internalSequenceID.indexOf(sequenceKey2)>=0){
//          sequence2Report = SandeshaClient.getOutgoingSequenceReport(to,sequenceKey2,configContext);
//        }
//     }
//    
//     assertNotNull(sequence1Report);
//     assertNotNull(sequence2Report);
//    
//     assertEquals(sequence1Report.getCompletedMessages().size(),2);
//     assertEquals(sequence2Report.getCompletedMessages().size(),2);
//    
//     assertEquals(sequence1Report.getSequenceStatus(),SequenceReport.SEQUENCE_STATUS_TERMINATED);
//     assertEquals(sequence2Report.getSequenceStatus(),SequenceReport.SEQUENCE_STATUS_TERMINATED); 
//  }
 
}
TOP

Related Classes of org.apache.sandesha2.SandeshaReportsTest

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.