/*
* *************************************************************************************
* 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.EPServiceProvider;
import com.espertech.esper.client.EPServiceProviderManager;
import com.espertech.esper.client.EPStatement;
import com.espertech.esper.client.EventBean;
import com.espertech.esper.client.scopetest.EPAssertionUtil;
import com.espertech.esper.client.scopetest.SupportUpdateListener;
import com.espertech.esper.support.bean.SupportBean_S0;
import com.espertech.esper.support.bean.SupportBean_S1;
import com.espertech.esper.support.bean.SupportBean_S2;
import com.espertech.esper.support.client.SupportConfigFactory;
import com.espertech.esper.support.util.ArrayHandlingUtil;
import com.espertech.esper.util.EventRepresentationEnum;
import junit.framework.TestCase;
public class Test3StreamOuterFullJoin extends TestCase
{
private final static String[] fields = new String[] {"s0.p00", "s0.p01", "s1.p10", "s1.p11", "s2.p20", "s2.p21", };
private final static String EVENT_S0 = SupportBean_S0.class.getName();
private final static String EVENT_S1 = SupportBean_S1.class.getName();
private final static String EVENT_S2 = SupportBean_S2.class.getName();
private EPServiceProvider epService;
private SupportUpdateListener updateListener;
public void setUp()
{
epService = EPServiceProviderManager.getDefaultProvider(SupportConfigFactory.getConfiguration());
epService.initialize();
updateListener = new SupportUpdateListener();
}
protected void tearDown() throws Exception {
updateListener = null;
}
public void testFullJoin_2sides_multicolumn() {
runAssertionFullJoin_2sides_multicolumn(EventRepresentationEnum.OBJECTARRAY);
runAssertionFullJoin_2sides_multicolumn(EventRepresentationEnum.MAP);
runAssertionFullJoin_2sides_multicolumn(EventRepresentationEnum.DEFAULT);
}
private void runAssertionFullJoin_2sides_multicolumn(EventRepresentationEnum eventRepresentationEnum)
{
String fields[] = "s0.id, s0.p00, s0.p01, s1.id, s1.p10, s1.p11, s2.id, s2.p20, s2.p21".split(",");
String joinStatement = eventRepresentationEnum.getAnnotationText() + " select * from " +
EVENT_S0 + ".win:length(1000) as s0 " +
" full outer join " + EVENT_S1 + ".win:length(1000) as s1 on s0.p00 = s1.p10 and s0.p01 = s1.p11" +
" full outer join " + EVENT_S2 + ".win:length(1000) as s2 on s0.p00 = s2.p20 and s0.p01 = s2.p21";
EPStatement joinView = epService.getEPAdministrator().createEPL(joinStatement);
joinView.addListener(updateListener);
epService.getEPRuntime().sendEvent(new SupportBean_S1(10, "A_1", "B_1"));
EPAssertionUtil.assertProps(updateListener.assertOneGetNewAndReset(), fields, new Object[]{null, null, null, 10, "A_1", "B_1", null, null, null});
epService.getEPRuntime().sendEvent(new SupportBean_S1(11, "A_2", "B_1"));
EPAssertionUtil.assertProps(updateListener.assertOneGetNewAndReset(), fields, new Object[]{null, null, null, 11, "A_2", "B_1", null, null, null});
epService.getEPRuntime().sendEvent(new SupportBean_S1(12, "A_1", "B_2"));
EPAssertionUtil.assertProps(updateListener.assertOneGetNewAndReset(), fields, new Object[]{null, null, null, 12, "A_1", "B_2", null, null, null});
epService.getEPRuntime().sendEvent(new SupportBean_S1(13, "A_2", "B_2"));
EPAssertionUtil.assertProps(updateListener.assertOneGetNewAndReset(), fields, new Object[]{null, null, null, 13, "A_2", "B_2", null, null, null});
epService.getEPRuntime().sendEvent(new SupportBean_S2(20, "A_1", "B_1"));
EPAssertionUtil.assertProps(updateListener.assertOneGetNewAndReset(), fields, new Object[]{null, null, null, null, null, null, 20, "A_1", "B_1"});
epService.getEPRuntime().sendEvent(new SupportBean_S2(21, "A_2", "B_1"));
EPAssertionUtil.assertProps(updateListener.assertOneGetNewAndReset(), fields, new Object[]{null, null, null, null, null, null, 21, "A_2", "B_1"});
epService.getEPRuntime().sendEvent(new SupportBean_S2(22, "A_1", "B_2"));
EPAssertionUtil.assertProps(updateListener.assertOneGetNewAndReset(), fields, new Object[]{null, null, null, null, null, null, 22, "A_1", "B_2"});
epService.getEPRuntime().sendEvent(new SupportBean_S2(23, "A_2", "B_2"));
EPAssertionUtil.assertProps(updateListener.assertOneGetNewAndReset(), fields, new Object[]{null, null, null, null, null, null, 23, "A_2", "B_2"});
epService.getEPRuntime().sendEvent(new SupportBean_S0(1, "A_3", "B_3"));
EPAssertionUtil.assertProps(updateListener.assertOneGetNewAndReset(), fields, new Object[]{1, "A_3", "B_3", null, null, null, null, null, null});
epService.getEPRuntime().sendEvent(new SupportBean_S0(2, "A_1", "B_3"));
EPAssertionUtil.assertProps(updateListener.assertOneGetNewAndReset(), fields, new Object[]{2, "A_1", "B_3", null, null, null, null, null, null});
epService.getEPRuntime().sendEvent(new SupportBean_S0(3, "A_3", "B_1"));
EPAssertionUtil.assertProps(updateListener.assertOneGetNewAndReset(), fields, new Object[]{3, "A_3", "B_1", null, null, null, null, null, null});
epService.getEPRuntime().sendEvent(new SupportBean_S0(4, "A_2", "B_2"));
EPAssertionUtil.assertProps(updateListener.assertOneGetNewAndReset(), fields, new Object[]{4, "A_2", "B_2", 13, "A_2", "B_2", 23, "A_2", "B_2"});
epService.getEPRuntime().sendEvent(new SupportBean_S0(5, "A_2", "B_1"));
EPAssertionUtil.assertProps(updateListener.assertOneGetNewAndReset(), fields, new Object[]{5, "A_2", "B_1", 11, "A_2", "B_1", 21, "A_2", "B_1"});
epService.getEPRuntime().sendEvent(new SupportBean_S1(14, "A_4", "B_3"));
EPAssertionUtil.assertProps(updateListener.assertOneGetNewAndReset(), fields, new Object[]{null, null, null, 14, "A_4", "B_3", null, null, null});
epService.getEPRuntime().sendEvent(new SupportBean_S1(15, "A_1", "B_3"));
EPAssertionUtil.assertProps(updateListener.assertOneGetNewAndReset(), fields, new Object[]{2, "A_1", "B_3", 15, "A_1", "B_3", null, null, null});
epService.getEPRuntime().sendEvent(new SupportBean_S2(24, "A_1", "B_3"));
EPAssertionUtil.assertProps(updateListener.assertOneGetNewAndReset(), fields, new Object[]{2, "A_1", "B_3", 15, "A_1", "B_3", 24, "A_1", "B_3"});
epService.getEPRuntime().sendEvent(new SupportBean_S2(25, "A_2", "B_3"));
EPAssertionUtil.assertProps(updateListener.assertOneGetNewAndReset(), fields, new Object[]{null, null, null, null, null, null, 25, "A_2", "B_3"});
epService.getEPAdministrator().destroyAllStatements();
}
public void testFullJoin_2sides()
{
/**
* Query:
* s0
* s1 <-> <-> s2
*/
String joinStatement = "select * from " +
EVENT_S0 + ".win:length(1000) as s0 " +
" full outer join " + EVENT_S1 + ".win:length(1000) as s1 on s0.p00 = s1.p10 " +
" full outer join " + EVENT_S2 + ".win:length(1000) as s2 on s0.p00 = s2.p20 ";
EPStatement joinView = epService.getEPAdministrator().createEPL(joinStatement);
joinView.addListener(updateListener);
runAssertsFullJoin_2sides(joinView);
}
private void runAssertsFullJoin_2sides(EPStatement joinView)
{
// Test s0 outer join to 2 streams, 2 results for each (cartesian product)
//
Object[] s1Events = SupportBean_S1.makeS1("A", new String[] {"A-s1-1", "A-s1-2"});
sendEvent(s1Events);
EPAssertionUtil.assertSameAnyOrder(new Object[][]{{null, s1Events[1], null}}, getAndResetNewEvents());
EPAssertionUtil.assertPropsPerRowAnyOrder(joinView.iterator(), fields,
new Object[][]{{null, null, "A", "A-s1-1", null, null},
{null, null, "A", "A-s1-2", null, null}});
Object[] s2Events = SupportBean_S2.makeS2("A", new String[] {"A-s2-1", "A-s2-2"});
sendEvent(s2Events);
EPAssertionUtil.assertSameAnyOrder(new Object[][]{{null, null, s2Events[1]}}, getAndResetNewEvents());
EPAssertionUtil.assertPropsPerRowAnyOrder(joinView.iterator(), fields,
new Object[][]{{null, null, "A", "A-s1-1", null, null},
{null, null, "A", "A-s1-2", null, null},
{null, null, null, null, "A", "A-s2-1"},
{null, null, null, null, "A", "A-s2-2"}});
Object[] s0Events = SupportBean_S0.makeS0("A", new String[] {"A-s0-1"});
sendEvent(s0Events);
Object[][] expected = new Object[][] {
{ s0Events[0], s1Events[0], s2Events[0] },
{ s0Events[0], s1Events[1], s2Events[0] },
{ s0Events[0], s1Events[0], s2Events[1] },
{ s0Events[0], s1Events[1], s2Events[1] },
};
EPAssertionUtil.assertSameAnyOrder(expected, getAndResetNewEvents());
EPAssertionUtil.assertPropsPerRowAnyOrder(joinView.iterator(), fields,
new Object[][]{{"A", "A-s0-1", "A", "A-s1-1", "A", "A-s2-1"},
{"A", "A-s0-1", "A", "A-s1-2", "A", "A-s2-1"},
{"A", "A-s0-1", "A", "A-s1-1", "A", "A-s2-2"},
{"A", "A-s0-1", "A", "A-s1-2", "A", "A-s2-2"}});
// Test s0 outer join to s1 and s2, no results for each s1 and s2
//
s0Events = SupportBean_S0.makeS0("B", new String[] {"B-s0-1"});
sendEvent(s0Events);
EPAssertionUtil.assertSameAnyOrder(new Object[][]{{s0Events[0], null, null}}, getAndResetNewEvents());
EPAssertionUtil.assertPropsPerRowAnyOrder(joinView.iterator(), fields,
new Object[][]{{"A", "A-s0-1", "A", "A-s1-1", "A", "A-s2-1"},
{"A", "A-s0-1", "A", "A-s1-2", "A", "A-s2-1"},
{"A", "A-s0-1", "A", "A-s1-1", "A", "A-s2-2"},
{"A", "A-s0-1", "A", "A-s1-2", "A", "A-s2-2"},
{"B", "B-s0-1", null, null, null, null}});
s0Events = SupportBean_S0.makeS0("B", new String[] {"B-s0-2"});
sendEvent(s0Events);
EPAssertionUtil.assertSameAnyOrder(new Object[][]{{s0Events[0], null, null}}, getAndResetNewEvents());
EPAssertionUtil.assertPropsPerRowAnyOrder(joinView.iterator(), fields,
new Object[][]{{"A", "A-s0-1", "A", "A-s1-1", "A", "A-s2-1"},
{"A", "A-s0-1", "A", "A-s1-2", "A", "A-s2-1"},
{"A", "A-s0-1", "A", "A-s1-1", "A", "A-s2-2"},
{"A", "A-s0-1", "A", "A-s1-2", "A", "A-s2-2"},
{"B", "B-s0-1", null, null, null, null},
{"B", "B-s0-2", null, null, null, null}});
// Test s0 outer join to s1 and s2, one row for s1 and no results for s2
//
s1Events = SupportBean_S1.makeS1("C", new String[] {"C-s1-1"});
sendEventsAndReset(s1Events);
EPAssertionUtil.assertPropsPerRowAnyOrder(joinView.iterator(), fields,
new Object[][]{{"A", "A-s0-1", "A", "A-s1-1", "A", "A-s2-1"},
{"A", "A-s0-1", "A", "A-s1-2", "A", "A-s2-1"},
{"A", "A-s0-1", "A", "A-s1-1", "A", "A-s2-2"},
{"A", "A-s0-1", "A", "A-s1-2", "A", "A-s2-2"},
{"B", "B-s0-1", null, null, null, null},
{"B", "B-s0-2", null, null, null, null},
{null, null, "C", "C-s1-1", null, null}});
s0Events = SupportBean_S0.makeS0("C", new String[] {"C-s0-1"});
sendEvent(s0Events);
EPAssertionUtil.assertSameAnyOrder(new Object[][]{{s0Events[0], s1Events[0], null}}, getAndResetNewEvents());
EPAssertionUtil.assertPropsPerRowAnyOrder(joinView.iterator(), fields,
new Object[][]{{"A", "A-s0-1", "A", "A-s1-1", "A", "A-s2-1"},
{"A", "A-s0-1", "A", "A-s1-2", "A", "A-s2-1"},
{"A", "A-s0-1", "A", "A-s1-1", "A", "A-s2-2"},
{"A", "A-s0-1", "A", "A-s1-2", "A", "A-s2-2"},
{"B", "B-s0-1", null, null, null, null},
{"B", "B-s0-2", null, null, null, null},
{"C", "C-s0-1", "C", "C-s1-1", null, null}});
// Test s0 outer join to s1 and s2, two rows for s1 and no results for s2
//
s1Events = SupportBean_S1.makeS1("D", new String[] {"D-s1-1", "D-s1-2"});
sendEventsAndReset(s1Events);
s0Events = SupportBean_S0.makeS0("D", new String[] {"D-s0-1"});
sendEvent(s0Events);
EPAssertionUtil.assertSameAnyOrder(new Object[][]{
{s0Events[0], s1Events[0], null},
{s0Events[0], s1Events[1], null}}, getAndResetNewEvents());
// Test s0 outer join to s1 and s2, one row for s2 and no results for s1
//
s2Events = SupportBean_S2.makeS2("E", new String[] {"E-s2-1"});
sendEventsAndReset(s2Events);
s0Events = SupportBean_S0.makeS0("E", new String[] {"E-s0-1"});
sendEvent(s0Events);
EPAssertionUtil.assertSameAnyOrder(new Object[][]{{s0Events[0], null, s2Events[0]}}, getAndResetNewEvents());
// Test s0 outer join to s1 and s2, two rows for s2 and no results for s1
//
s2Events = SupportBean_S2.makeS2("F", new String[] {"F-s2-1", "F-s2-2"});
sendEventsAndReset(s2Events);
s0Events = SupportBean_S0.makeS0("F", new String[] {"F-s0-1"});
sendEvent(s0Events);
EPAssertionUtil.assertSameAnyOrder(new Object[][]{
{s0Events[0], null, s2Events[0]},
{s0Events[0], null, s2Events[1]}}, getAndResetNewEvents());
// Test s0 outer join to s1 and s2, one row for s1 and two rows s2
//
s1Events = SupportBean_S1.makeS1("G", new String[] {"G-s1-1"});
sendEventsAndReset(s1Events);
s2Events = SupportBean_S2.makeS2("G", new String[] {"G-s2-1", "G-s2-2"});
sendEventsAndReset(s2Events);
s0Events = SupportBean_S0.makeS0("G", new String[] {"G-s0-2"});
sendEvent(s0Events);
expected = new Object[][] {
{ s0Events[0], s1Events[0], s2Events[0] },
{ s0Events[0], s1Events[0], s2Events[1] },
};
EPAssertionUtil.assertSameAnyOrder(expected, getAndResetNewEvents());
// Test s0 outer join to s1 and s2, one row for s2 and two rows s1
//
s1Events = SupportBean_S1.makeS1("H", new String[] {"H-s1-1", "H-s1-2"});
sendEventsAndReset(s1Events);
s2Events = SupportBean_S2.makeS2("H", new String[] {"H-s2-1"});
sendEventsAndReset(s2Events);
s0Events = SupportBean_S0.makeS0("H", new String[] {"H-s0-2"});
sendEvent(s0Events);
expected = new Object[][] {
{ s0Events[0], s1Events[0], s2Events[0] },
{ s0Events[0], s1Events[1], s2Events[0] },
};
EPAssertionUtil.assertSameAnyOrder(expected, getAndResetNewEvents());
// Test s0 outer join to s1 and s2, one row for each s1 and s2
//
s1Events = SupportBean_S1.makeS1("I", new String[] {"I-s1-1"});
sendEventsAndReset(s1Events);
s2Events = SupportBean_S2.makeS2("I", new String[] {"I-s2-1"});
sendEventsAndReset(s2Events);
s0Events = SupportBean_S0.makeS0("I", new String[] {"I-s0-2"});
sendEvent(s0Events);
expected = new Object[][] {
{ s0Events[0], s1Events[0], s2Events[0] },
};
EPAssertionUtil.assertSameAnyOrder(expected, getAndResetNewEvents());
// Test s1 inner join to s0 and outer to s2: s0 with 1 rows, s2 with 2 rows
//
s0Events = SupportBean_S0.makeS0("Q", new String[] {"Q-s0-1"});
sendEvent(s0Events);
EPAssertionUtil.assertSameAnyOrder(new Object[][]{{s0Events[0], null, null}}, getAndResetNewEvents());
s2Events = SupportBean_S2.makeS2("Q", new String[] {"Q-s2-1", "Q-s2-2"});
sendEvent(s2Events[0]);
EPAssertionUtil.assertSameAnyOrder(new Object[][]{{s0Events[0], null, s2Events[0]}}, getAndResetNewEvents());
sendEvent(s2Events[1]);
EPAssertionUtil.assertSameAnyOrder(new Object[][]{{s0Events[0], null, s2Events[1]}}, getAndResetNewEvents());
s1Events = SupportBean_S1.makeS1("Q", new String[] {"Q-s1-1"});
sendEvent(s1Events);
expected = new Object[][] {
{ s0Events[0], s1Events[0], s2Events[0] },
{ s0Events[0], s1Events[0], s2Events[1] },
};
EPAssertionUtil.assertSameAnyOrder(expected, getAndResetNewEvents());
// Test s1 inner join to s0 and outer to s2: s0 with 0 rows, s2 with 2 rows
//
s2Events = SupportBean_S2.makeS2("R", new String[] {"R-s2-1", "R-s2-2"});
sendEvent(s2Events);
EPAssertionUtil.assertSameAnyOrder(new Object[][]{{null, null, s2Events[1]}}, getAndResetNewEvents());
s1Events = SupportBean_S1.makeS1("R", new String[] {"R-s1-1"});
sendEvent(s1Events);
EPAssertionUtil.assertSameAnyOrder(new Object[][]{{null, s1Events[0], null}}, getAndResetNewEvents());
// Test s1 inner join to s0 and outer to s2: s0 with 1 rows, s2 with 0 rows
//
s0Events = SupportBean_S0.makeS0("S", new String[] {"S-s0-1"});
sendEvent(s0Events);
EPAssertionUtil.assertSameAnyOrder(new Object[][]{{s0Events[0], null, null}}, getAndResetNewEvents());
s1Events = SupportBean_S1.makeS1("S", new String[] {"S-s1-1"});
sendEvent(s1Events);
EPAssertionUtil.assertSameAnyOrder(new Object[][]{{s0Events[0], s1Events[0], null}}, getAndResetNewEvents());
// Test s1 inner join to s0 and outer to s2: s0 with 1 rows, s2 with 1 rows
//
s0Events = SupportBean_S0.makeS0("T", new String[] {"T-s0-1"});
sendEvent(s0Events);
EPAssertionUtil.assertSameAnyOrder(new Object[][]{{s0Events[0], null, null}}, getAndResetNewEvents());
s2Events = SupportBean_S2.makeS2("T", new String[] {"T-s2-1"});
sendEventsAndReset(s2Events);
s1Events = SupportBean_S1.makeS1("T", new String[] {"T-s1-1"});
sendEvent(s1Events);
EPAssertionUtil.assertSameAnyOrder(new Object[][]{{s0Events[0], s1Events[0], s2Events[0]}}, getAndResetNewEvents());
// Test s1 inner join to s0 and outer to s2: s0 with 2 rows, s2 with 0 rows
//
s0Events = SupportBean_S0.makeS0("U", new String[] {"U-s0-1", "U-s0-1"});
sendEventsAndReset(s0Events);
s1Events = SupportBean_S1.makeS1("U", new String[] {"U-s1-1"});
sendEvent(s1Events);
expected = new Object[][] {
{ s0Events[0], s1Events[0], null },
{ s0Events[1], s1Events[0], null },
};
EPAssertionUtil.assertSameAnyOrder(expected, getAndResetNewEvents());
// Test s1 inner join to s0 and outer to s2: s0 with 2 rows, s2 with 1 rows
//
s0Events = SupportBean_S0.makeS0("V", new String[] {"V-s0-1", "V-s0-1"});
sendEventsAndReset(s0Events);
s2Events = SupportBean_S2.makeS2("V", new String[] {"V-s2-1"});
sendEventsAndReset(s2Events);
s1Events = SupportBean_S1.makeS1("V", new String[] {"V-s1-1"});
sendEvent(s1Events);
expected = new Object[][] {
{ s0Events[0], s1Events[0], s2Events[0] },
{ s0Events[1], s1Events[0], s2Events[0] },
};
EPAssertionUtil.assertSameAnyOrder(expected, getAndResetNewEvents());
// Test s1 inner join to s0 and outer to s2: s0 with 2 rows, s2 with 2 rows
//
s0Events = SupportBean_S0.makeS0("W", new String[] {"W-s0-1", "W-s0-2"});
sendEventsAndReset(s0Events);
s2Events = SupportBean_S2.makeS2("W", new String[] {"W-s2-1", "W-s2-2"});
sendEventsAndReset(s2Events);
s1Events = SupportBean_S1.makeS1("W", new String[] {"W-s1-1"});
sendEvent(s1Events);
expected = new Object[][] {
{ s0Events[0], s1Events[0], s2Events[0] },
{ s0Events[1], s1Events[0], s2Events[0] },
{ s0Events[0], s1Events[0], s2Events[1] },
{ s0Events[1], s1Events[0], s2Events[1] },
};
EPAssertionUtil.assertSameAnyOrder(expected, getAndResetNewEvents());
// Test s2 inner join to s0 and outer to s1: s0 with 1 rows, s1 with 2 rows
//
s0Events = SupportBean_S0.makeS0("J", new String[] {"J-s0-1"});
sendEventsAndReset(s0Events);
s1Events = SupportBean_S1.makeS1("J", new String[] {"J-s1-1", "J-s1-2"});
sendEventsAndReset(s1Events);
s2Events = SupportBean_S2.makeS2("J", new String[] {"J-s2-1"});
sendEvent(s2Events);
expected = new Object[][] {
{ s0Events[0], s1Events[0], s2Events[0] },
{ s0Events[0], s1Events[1], s2Events[0] },
};
EPAssertionUtil.assertSameAnyOrder(expected, getAndResetNewEvents());
// Test s2 inner join to s0 and outer to s1: s0 with 0 rows, s1 with 2 rows
//
s1Events = SupportBean_S1.makeS1("K", new String[] {"K-s1-1", "K-s1-2"});
sendEventsAndReset(s2Events);
s2Events = SupportBean_S2.makeS2("K", new String[] {"K-s2-1"});
sendEventsAndReset(s2Events);
// Test s2 inner join to s0 and outer to s1: s0 with 1 rows, s1 with 0 rows
//
s0Events = SupportBean_S0.makeS0("L", new String[] {"L-s0-1"});
sendEventsAndReset(s0Events);
s2Events = SupportBean_S2.makeS2("L", new String[] {"L-s2-1"});
sendEvent(s2Events);
EPAssertionUtil.assertSameAnyOrder(new Object[][]{{s0Events[0], null, s2Events[0]}}, getAndResetNewEvents());
// Test s2 inner join to s0 and outer to s1: s0 with 1 rows, s1 with 1 rows
//
s0Events = SupportBean_S0.makeS0("M", new String[] {"M-s0-1"});
sendEventsAndReset(s0Events);
s1Events = SupportBean_S1.makeS1("M", new String[] {"M-s1-1"});
sendEventsAndReset(s1Events);
s2Events = SupportBean_S2.makeS2("M", new String[] {"M-s2-1"});
sendEvent(s2Events);
EPAssertionUtil.assertSameAnyOrder(new Object[][]{{s0Events[0], s1Events[0], s2Events[0]}}, getAndResetNewEvents());
// Test s2 inner join to s0 and outer to s1: s0 with 2 rows, s1 with 0 rows
//
s0Events = SupportBean_S0.makeS0("N", new String[] {"N-s0-1", "N-s0-1"});
sendEventsAndReset(s0Events);
s2Events = SupportBean_S2.makeS2("N", new String[] {"N-s2-1"});
sendEvent(s2Events);
expected = new Object[][] {
{ s0Events[0], null, s2Events[0]},
{ s0Events[1], null, s2Events[0]},
};
EPAssertionUtil.assertSameAnyOrder(expected, getAndResetNewEvents());
// Test s2 inner join to s0 and outer to s1: s0 with 2 rows, s1 with 1 rows
//
s0Events = SupportBean_S0.makeS0("O", new String[] {"O-s0-1", "O-s0-1"});
sendEventsAndReset(s0Events);
s1Events = SupportBean_S1.makeS1("O", new String[] {"O-s1-1"});
sendEventsAndReset(s1Events);
s2Events = SupportBean_S2.makeS2("O", new String[] {"O-s2-1"});
sendEvent(s2Events);
expected = new Object[][] {
{ s0Events[0], s1Events[0], s2Events[0] },
{ s0Events[1], s1Events[0], s2Events[0] },
};
EPAssertionUtil.assertSameAnyOrder(expected, getAndResetNewEvents());
// Test s2 inner join to s0 and outer to s1: s0 with 2 rows, s1 with 2 rows
//
s0Events = SupportBean_S0.makeS0("P", new String[] {"P-s0-1", "P-s0-2"});
sendEventsAndReset(s0Events);
s1Events = SupportBean_S1.makeS1("P", new String[] {"P-s1-1", "P-s1-2"});
sendEventsAndReset(s1Events);
s2Events = SupportBean_S2.makeS2("P", new String[] {"P-s2-1"});
sendEvent(s2Events);
expected = new Object[][] {
{ s0Events[0], s1Events[0], s2Events[0] },
{ s0Events[1], s1Events[0], s2Events[0] },
{ s0Events[0], s1Events[1], s2Events[0] },
{ s0Events[1], s1Events[1], s2Events[0] },
};
EPAssertionUtil.assertSameAnyOrder(expected, getAndResetNewEvents());
}
private void sendEvent(Object theEvent)
{
epService.getEPRuntime().sendEvent(theEvent);
}
private void sendEventsAndReset(Object[] events)
{
sendEvent(events);
updateListener.reset();
}
private void sendEvent(Object[] events)
{
for (int i = 0; i < events.length; i++)
{
epService.getEPRuntime().sendEvent(events[i]);
}
}
private Object[][] getAndResetNewEvents()
{
EventBean[] newEvents = updateListener.getLastNewData();
updateListener.reset();
return ArrayHandlingUtil.getUnderlyingEvents(newEvents, new String[] {"s0", "s1", "s2"});
}
}