/* *************************************************************************************** * 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.resultset; import com.espertech.esper.client.EPServiceProvider; import com.espertech.esper.client.EPServiceProviderManager; import com.espertech.esper.client.EPStatement; import com.espertech.esper.client.scopetest.SupportUpdateListener; 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 com.espertech.esper.supportregression.util.SupportMessageAssertUtil; import junit.framework.TestCase; public class TestCount extends TestCase { private EPServiceProvider epService; private SupportUpdateListener listener; private EPStatement selectTestView; public void setUp() { listener = new SupportUpdateListener(); epService = EPServiceProviderManager.getDefaultProvider(SupportConfigFactory.getConfiguration()); 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 testCountPlusStar() { // Test for ESPER-118 String statementText = "select *, count(*) as cnt from " + SupportMarketDataBean.class.getName(); selectTestView = epService.getEPAdministrator().createEPL(statementText); selectTestView.addListener(listener); sendEvent("S0", 1L); assertTrue(listener.getAndClearIsInvoked()); assertEquals(1, listener.getLastNewData().length); assertEquals(1L, listener.getLastNewData()[0].get("cnt")); assertEquals("S0", listener.getLastNewData()[0].get("symbol")); sendEvent("S1", 1L); assertTrue(listener.getAndClearIsInvoked()); assertEquals(1, listener.getLastNewData().length); assertEquals(2L, listener.getLastNewData()[0].get("cnt")); assertEquals("S1", listener.getLastNewData()[0].get("symbol")); sendEvent("S2", 1L); assertTrue(listener.getAndClearIsInvoked()); assertEquals(1, listener.getLastNewData().length); assertEquals(3L, listener.getLastNewData()[0].get("cnt")); assertEquals("S2", listener.getLastNewData()[0].get("symbol")); } public void testCount() { String statementText = "select count(*) as cnt from " + SupportMarketDataBean.class.getName() + "#time(1)"; selectTestView = epService.getEPAdministrator().createEPL(statementText); selectTestView.addListener(listener); sendEvent("DELL", 1L); assertTrue(listener.getAndClearIsInvoked()); assertEquals(1, listener.getLastNewData().length); assertEquals(1L, listener.getLastNewData()[0].get("cnt")); sendEvent("DELL", 1L); assertTrue(listener.getAndClearIsInvoked()); assertEquals(1, listener.getLastNewData().length); assertEquals(2L, listener.getLastNewData()[0].get("cnt")); sendEvent("DELL", 1L); assertTrue(listener.getAndClearIsInvoked()); assertEquals(1, listener.getLastNewData().length); assertEquals(3L, listener.getLastNewData()[0].get("cnt")); // test invalid distinct SupportMessageAssertUtil.tryInvalid(epService, "select count(distinct *) from " + SupportMarketDataBean.class.getName(), "Error starting statement: Failed to validate select-clause expression 'count(distinct *)': Invalid use of the 'distinct' keyword with count and wildcard"); } public void testCountHaving() { String theEvent = SupportBean.class.getName(); String statementText = "select irstream sum(intPrimitive) as mysum from " + theEvent + " having sum(intPrimitive) = 2"; selectTestView = epService.getEPAdministrator().createEPL(statementText); selectTestView.addListener(listener); sendEvent(); assertFalse(listener.getAndClearIsInvoked()); sendEvent(); assertEquals(2, listener.assertOneGetNewAndReset().get("mysum")); sendEvent(); assertEquals(2, listener.assertOneGetOldAndReset().get("mysum")); } public void testSumHaving() { String theEvent = SupportBean.class.getName(); String statementText = "select irstream count(*) as mysum from " + theEvent + " having count(*) = 2"; selectTestView = epService.getEPAdministrator().createEPL(statementText); selectTestView.addListener(listener); sendEvent(); assertFalse(listener.getAndClearIsInvoked()); sendEvent(); assertEquals(2L, listener.assertOneGetNewAndReset().get("mysum")); sendEvent(); assertEquals(2L, listener.assertOneGetOldAndReset().get("mysum")); } private void sendEvent(String symbol, Long volume) { SupportMarketDataBean bean = new SupportMarketDataBean(symbol, 0, volume, "f1"); epService.getEPRuntime().sendEvent(bean); } private void sendEvent() { SupportBean bean = new SupportBean("", 1); epService.getEPRuntime().sendEvent(bean); } }