/* * ************************************************************************************* * Copyright (C) 2008 EsperTech, Inc. All rights reserved. * * http://esper.codehaus.org * * http://www.espertech.com * * ---------------------------------------------------------------------------------- * * The software in this package is published under the terms of the GPL license * * a copy of which has been included with this distribution in the license.txt file. * * ************************************************************************************* */ package com.espertech.esper.regression.epl; import com.espertech.esper.client.scopetest.SupportUpdateListener; import junit.framework.TestCase; import com.espertech.esper.client.Configuration; import com.espertech.esper.client.EPServiceProvider; import com.espertech.esper.client.EPServiceProviderManager; import com.espertech.esper.client.EPStatement; import com.espertech.esper.support.bean.SupportMarketDataIDBean; import com.espertech.esper.support.client.SupportConfigFactory; public class TestPerfTimeWindowMinFilter extends TestCase { private EPServiceProvider epService; public void setUp() { Configuration config = SupportConfigFactory.getConfiguration(); config.addEventType("MD", SupportMarketDataIDBean.class); epService = EPServiceProviderManager.getDefaultProvider(config); epService.initialize(); } public void tearDown() { epService.initialize(); } public void testPerf() { EPStatement[] statements = new EPStatement[100]; SupportUpdateListener listeners[] = new SupportUpdateListener[statements.length]; for (int i = 0; i < statements.length; i++) { int secondsWindowSpan = i % 30 + 1; double percent = 0.25 + i; int id = i % 5; String text = "select symbol, min(price) " + "from MD(id='${id}').win:time(${secondsWindowSpan})\n" + "having price >= min(price) * ${percent}"; text = text.replace("${id}", Integer.toString(id)); text = text.replace("${secondsWindowSpan}", Integer.toString(secondsWindowSpan)); text = text.replace("${percent}", Double.toString(percent)); statements[i] = epService.getEPAdministrator().createEPL(text); listeners[i] = new SupportUpdateListener(); statements[i].addListener(listeners[i]); } long start = System.currentTimeMillis(); int count = 0; for (int i = 0; i < 10000; i++) { count++; if (i % 10000 == 0) { long now = System.currentTimeMillis(); double deltaSec = (now - start) / 1000.0; double throughput = 10000.0 / deltaSec; for (int j = 0; j < listeners.length; j++) { listeners[j].reset(); } start = now; } SupportMarketDataIDBean bean = new SupportMarketDataIDBean("IBM", Integer.toString(i % 5), 1); epService.getEPRuntime().sendEvent(bean); } long end = System.currentTimeMillis(); long delta = end - start; assertTrue("Delta=" + delta, delta < 2000); //System.out.println("total=" + count + " delta=" + delta + " per sec:" + 10000.0 / (delta / 1000.0)); } }