/*
***************************************************************************************
* Copyright (C) 2006 EsperTech, Inc. All rights reserved. *
* http://www.espertech.com/esper *
* 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.view;
import com.espertech.esper.client.*;
import com.espertech.esper.client.scopetest.EPAssertionUtil;
import com.espertech.esper.client.scopetest.SupportUpdateListener;
import com.espertech.esper.client.time.CurrentTimeEvent;
import com.espertech.esper.client.util.DateTime;
import com.espertech.esper.metrics.instrumentation.InstrumentationHelper;
import com.espertech.esper.supportregression.bean.SupportBean;
import com.espertech.esper.supportregression.bean.SupportMarketDataBean;
import com.espertech.esper.supportregression.client.SupportConfigFactory;
import junit.framework.TestCase;
public class TestViewTimeWindowUnique extends TestCase
{
private EPServiceProvider epService;
private SupportUpdateListener listener;
public void setUp()
{
listener = new SupportUpdateListener();
Configuration config = SupportConfigFactory.getConfiguration();
config.getEngineDefaults().getViewResources().setAllowMultipleExpiryPolicies(true);
epService = EPServiceProviderManager.getDefaultProvider(config);
epService.initialize();
if (InstrumentationHelper.ENABLED) { InstrumentationHelper.startTest(epService, this.getClass(), getName());}
}
protected void tearDown() throws Exception {
if (InstrumentationHelper.ENABLED) { InstrumentationHelper.endTest();}
listener = null;
}
public void testMonthScoped() {
epService.getEPAdministrator().getConfiguration().addEventType(SupportBean.class);
sendCurrentTime("2002-02-01T09:00:00.000");
epService.getEPAdministrator().createEPL("select rstream * from SupportBean#time(1 month)").addListener(listener);
epService.getEPRuntime().sendEvent(new SupportBean("E1", 1));
sendCurrentTime("2002-02-15T09:00:00.000");
epService.getEPRuntime().sendEvent(new SupportBean("E2", 2));
sendCurrentTimeWithMinus("2002-03-01T09:00:00.000", 1);
assertFalse(listener.isInvoked());
sendCurrentTime("2002-03-01T09:00:00.000");
EPAssertionUtil.assertProps(listener.assertOneGetNewAndReset(), "theString".split(","), new Object[]{"E1"});
sendCurrentTimeWithMinus("2002-03-15T09:00:00.000", 1);
assertFalse(listener.isInvoked());
sendCurrentTime("2002-03-15T09:00:00.000");
EPAssertionUtil.assertProps(listener.assertOneGetNewAndReset(), "theString".split(","), new Object[] {"E2"});
}
// Make sure the timer and dispatch works for externally timed events and views
public void testWindowUnique()
{
// Set up a time window with a unique view attached
EPStatement windowUniqueView = epService.getEPAdministrator().createEPL(
"select irstream * from " + SupportMarketDataBean.class.getName() +
"#time(3.0)#unique(symbol)");
windowUniqueView.addListener(listener);
sendTimer(0);
sendEvent("IBM");
assertNull(listener.getLastOldData());
sendTimer(4000);
assertEquals(1, listener.getLastOldData().length);
}
// Make sure the timer and dispatch works for externally timed events and views
public void testWindowUniqueMultiKey()
{
sendTimer(0);
// Set up a time window with a unique view attached
EPStatement windowUniqueView = epService.getEPAdministrator().createEPL(
"select irstream * from " + SupportMarketDataBean.class.getName() +
"#time(3.0)#unique(symbol, price)");
windowUniqueView.addListener(listener);
String[] fields = new String[] {"symbol", "price", "volume"};
sendEvent("IBM", 10, 1L);
EPAssertionUtil.assertProps(listener.assertOneGetNewAndReset(), fields, new Object[]{"IBM", 10.0, 1L});
sendEvent("IBM", 11, 2L);
EPAssertionUtil.assertProps(listener.assertOneGetNewAndReset(), fields, new Object[]{"IBM", 11.0, 2L});
sendEvent("IBM", 10, 3L);
EPAssertionUtil.assertProps(listener.getLastNewData()[0], fields, new Object[]{"IBM", 10.0, 3L});
EPAssertionUtil.assertProps(listener.getLastOldData()[0], fields, new Object[]{"IBM", 10.0, 1L});
listener.reset();
sendEvent("IBM", 11, 4L);
EPAssertionUtil.assertProps(listener.getLastNewData()[0], fields, new Object[]{"IBM", 11.0, 4L});
EPAssertionUtil.assertProps(listener.getLastOldData()[0], fields, new Object[]{"IBM", 11.0, 2L});
listener.reset();
sendTimer(2000);
sendEvent(null, 11, 5L);
EPAssertionUtil.assertProps(listener.assertOneGetNewAndReset(), fields, new Object[]{null, 11.0, 5L});
sendTimer(3000);
assertEquals(2, listener.getLastOldData().length);
EPAssertionUtil.assertProps(listener.getLastOldData()[0], fields, new Object[]{"IBM", 10.0, 3L});
EPAssertionUtil.assertProps(listener.getLastOldData()[1], fields, new Object[]{"IBM", 11.0, 4L});
listener.reset();
sendEvent(null, 11, 6L);
EPAssertionUtil.assertProps(listener.getLastNewData()[0], fields, new Object[]{null, 11.0, 6L});
EPAssertionUtil.assertProps(listener.getLastOldData()[0], fields, new Object[]{null, 11.0, 5L});
listener.reset();
sendTimer(6000);
assertEquals(1, listener.getLastOldData().length);
EPAssertionUtil.assertProps(listener.getLastOldData()[0], fields, new Object[]{null, 11.0, 6L});
listener.reset();
}
private void sendEvent(String symbol)
{
SupportMarketDataBean theEvent = new SupportMarketDataBean(symbol, 0, 0L, "");
epService.getEPRuntime().sendEvent(theEvent);
}
private void sendEvent(String symbol, double price, Long volume)
{
SupportMarketDataBean theEvent = new SupportMarketDataBean(symbol, price, volume, "");
epService.getEPRuntime().sendEvent(theEvent);
}
private void sendTimer(long time)
{
CurrentTimeEvent theEvent = new CurrentTimeEvent(time);
EPRuntime runtime = epService.getEPRuntime();
runtime.sendEvent(theEvent);
}
private void sendCurrentTime(String time) {
epService.getEPRuntime().sendEvent(new CurrentTimeEvent(DateTime.parseDefaultMSec(time)));
}
private void sendCurrentTimeWithMinus(String time, long minus) {
epService.getEPRuntime().sendEvent(new CurrentTimeEvent(DateTime.parseDefaultMSec(time) - minus));
}
}