XPathRouteConcurrentBigTest.java :  » Library » camel » org » apache » camel » language » Java Open Source

Java Open Source » Library » camel 
camel » org » apache » camel » language » XPathRouteConcurrentBigTest.java
/**
 * Licensed to the Apache Software Foundation (ASF) under one or more
 * contributor license agreements.  See the NOTICE file distributed with
 * this work for additional information regarding copyright ownership.
 * The ASF licenses this file to You 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.camel.language;

import org.apache.camel.ContextTestSupport;
import org.apache.camel.builder.RouteBuilder;
import org.apache.commons.logging.Log;
import org.apache.commons.logging.LogFactory;

/**
 * @version $Revision: 825096 $
 */
public class XPathRouteConcurrentBigTest extends ContextTestSupport {

    private static final transient Log LOG = LogFactory.getLog(XPathRouteConcurrentBigTest.class);

    private static final String XMLTEST1 =
            "<message><messageType>AAA</messageType><sender>0123456789101112131415</sender>"
            + "<rawData>Uyw7TSVkUMxUyw7TSgGUMQAyw7TSVkUMxUyA7TSgGUMQAyw7TSVkUMxUyA</rawData>"
            + "<sentDate>2009-10-12T12:22:02+02:00</sentDate> <receivedDate>2009-10-12T12:23:31.248+02:00</receivedDate>"
            + "<intproperty>1</intproperty><stringproperty>aaaaaaabbbbbbbccccccccdddddddd</stringproperty></message>";
    private static final String XMLTEST2 =
            "<message><messageType>AAB</messageType><sender>0123456789101112131415</sender>"
            + "<rawData>Uyw7TSVkUMxUyw7TSgGUMQAyw7TSVkUMxUyA7TSgGUMQAyw7TSVkUMxUyA</rawData>"
            + "<sentDate>2009-10-12T12:22:02+02:00</sentDate> <receivedDate>2009-10-12T12:23:31.248+02:00</receivedDate>"
            + "<intproperty>1</intproperty><stringproperty>aaaaaaabbbbbbbccccccccdddddddd</stringproperty></message>";
    private static final String XMLTEST3 =
            "<message><messageType>ZZZ</messageType><sender>0123456789101112131415</sender>"
            + "<rawData>Uyw7TSVkUMxUyw7TSgGUMQAyw7TSVkUMxUyA7TSgGUMQAyw7TSVkUMxUyA</rawData>"
            + "<sentDate>2009-10-12T12:22:02+02:00</sentDate> <receivedDate>2009-10-12T12:23:31.248+02:00</receivedDate>"
            + "<intproperty>1</intproperty><stringproperty>aaaaaaabbbbbbbccccccccdddddddd</stringproperty></message>";

    public void testConcurrent() throws Exception {
        doSendMessages(333);
    }

    private void doSendMessages(int messageCount) throws Exception {
        LOG.info("Sending " + messageCount + " messages");

        int forResult = (messageCount * 2 / 3) + messageCount % 3;
        int forOther = messageCount - forResult;

        long now = System.currentTimeMillis();

        // give more time on slow servers
        getMockEndpoint("mock:result").setResultWaitTime(30000);
        getMockEndpoint("mock:other").setResultWaitTime(30000);

        getMockEndpoint("mock:result").expectedMessageCount(forResult);
        getMockEndpoint("mock:other").expectedMessageCount(forOther);

        for (int i = 0; i < messageCount; i++) {
            switch (i % 3) {
            case 0:
                template.sendBody("seda:foo", XMLTEST1);
                break;
            case 1:
                template.sendBody("seda:foo", XMLTEST2);
                break;
            case 2:
                template.sendBody("seda:foo", XMLTEST3);
                break;
            default:
                break;
            }
        }

        LOG.info("Sent " + messageCount + " messages in " + (System.currentTimeMillis() - now) + " ms");

        assertMockEndpointsSatisfied();

        LOG.info("Processed " + messageCount + " messages in " + (System.currentTimeMillis() - now) + " ms");
    }

    @Override
    protected RouteBuilder createRouteBuilder() throws Exception {
        return new RouteBuilder() {
            @Override
            public void configure() throws Exception {
                from("seda:foo?concurrentConsumers=50&size=250000").choice()
                    .when()
                        .xpath("//messageType = 'AAA' or "
                                + "//messageType = 'AAB' or "
                                + "//messageType = 'AAC' or "
                                + "//messageType = 'AAD' or "
                                + "//messageType = 'AAE' or "
                                + "//messageType = 'AAF' or "
                                + "//messageType = 'AAG' or "
                                + "//messageType = 'AAH' or "
                                + "//messageType = 'AAI' or "
                                + "//messageType = 'AAJ' or "
                                + "//messageType = 'AAK' or "
                                + "//messageType = 'AAL' or "
                                + "//messageType = 'AAM' or "
                                + "//messageType = 'AAN' or "
                                + "//messageType = 'AAO' or "
                                + "//messageType = 'AAP' or "
                                + "//messageType = 'AAQ' or "
                                + "//messageType = 'AAR' or "
                                + "//messageType = 'AAS' or "
                                + "//messageType = 'AAT' or "
                                + "//messageType = 'AAU' or "
                                + "//messageType = 'AAV' or "
                                + "//messageType = 'AAW' or "
                                + "//messageType = 'AAX' or "
                                + "//messageType = 'AAY' or "
                                + "//messageType = 'AAZ'")
                        .to("mock:result")
                    .otherwise()
                        .to("mock:other")
                    .end();
            }
        };
    }

}
java2s.com  | Contact Us | Privacy Policy
Copyright 2009 - 12 Demo Source and Support. All rights reserved.
All other trademarks are property of their respective owners.