public void Run(RegressionEnvironment env) { string[] fields = "c0,c1,c2".SplitCsv(); SupportEvalBuilder builder = new SupportEvalBuilder("SupportCollection"); builder.WithExpression(fields[0], "Strvals.groupBy(c => extractAfterUnderscore(c))"); builder.WithExpression(fields[1], "Strvals.groupBy((c, i) => extractAfterUnderscore(c) || '_' || Convert.ToString(i))"); builder.WithExpression( fields[2], "Strvals.groupBy((c, i, s) => extractAfterUnderscore(c) || '_' || Convert.ToString(i) || '_' || Convert.ToString(s))"); builder.WithStatementConsumer(stmt => AssertTypesAllSame(stmt.EventType, fields, typeof(IDictionary <object, object>))); builder.WithAssertion(SupportCollection.MakeString("E1_2,E2_1,E3_2")) .Verify("c0", val => CompareMaps(val, "2,1", new[] { "E1_2,E3_2", "E2_1" }, GetExtractorScalar())) .Verify("c1", val => CompareMaps(val, "2_0,1_1,2_2", new[] { "E1_2", "E2_1", "E3_2" }, GetExtractorScalar())) .Verify("c2", val => CompareMaps(val, "2_0_3,1_1_3,2_2_3", new[] { "E1_2", "E2_1", "E3_2" }, GetExtractorScalar())); SupportEvalAssertionBuilder assertionNull = builder.WithAssertion(SupportCollection.MakeString(null)); foreach (string field in fields) { assertionNull.Verify(field, Assert.IsNull); } SupportEvalAssertionBuilder assertionEmpty = builder.WithAssertion(SupportCollection.MakeString("")); foreach (string field in fields) { assertionEmpty.Verify(field, val => CompareMaps(val, "", new string[0], GetExtractorScalar())); } builder.Run(env); }
public void Run(RegressionEnvironment env) { string[] fields = "c0,c1".SplitCsv(); SupportEvalBuilder builder = new SupportEvalBuilder("SupportCollection"); builder.WithExpression(fields[0], "Strvals.selectFrom( (v, i) => v || '_' || Convert.ToString(i))"); builder.WithExpression(fields[1], "Strvals.selectFrom( (v, i, s) => v || '_' || Convert.ToString(i) || '_' || Convert.ToString(s))"); builder.WithStatementConsumer(stmt => AssertTypesAllSame(stmt.EventType, fields, typeof(ICollection <object>))); builder.WithAssertion(SupportCollection.MakeString("E1,E2,E3")) .Verify(fields[0], value => AssertValuesArrayScalar(value, "E1_0", "E2_1", "E3_2")) .Verify(fields[1], value => AssertValuesArrayScalar(value, "E1_0_3", "E2_1_3", "E3_2_3")); builder.WithAssertion(SupportCollection.MakeString("")) .Verify(fields[0], value => AssertValuesArrayScalar(value)) .Verify(fields[1], value => AssertValuesArrayScalar(value)); builder.WithAssertion(SupportCollection.MakeString("E1")) .Verify(fields[0], value => AssertValuesArrayScalar(value, "E1_0")) .Verify(fields[1], value => AssertValuesArrayScalar(value, "E1_0_1")); builder.WithAssertion(SupportCollection.MakeString(null)) .Verify(fields[0], Assert.IsNull) .Verify(fields[1], Assert.IsNull); builder.Run(env); }
public void Run(RegressionEnvironment env) { string[] fields = "c0,c1,c2,c3".SplitCsv(); SupportEvalBuilder builder = new SupportEvalBuilder("SupportBean_ST0_Container"); builder.WithExpression(fields[0], "Contained.countof()"); builder.WithExpression(fields[1], "Contained.countof(x => x.P00 = 9)"); builder.WithExpression(fields[2], "Contained.countof((x, i) => x.P00 + i = 10)"); builder.WithExpression(fields[3], "Contained.countof((x, i, s) => x.P00 + i + s = 100)"); builder.WithStatementConsumer(stmt => AssertTypesAllSame(stmt.EventType, fields, typeof(int?))); builder.WithAssertion(SupportBean_ST0_Container.Make2Value("E1,1", "E2,9", "E2,9")).Expect(fields, 3, 2, 1, 0); builder.WithAssertion(SupportBean_ST0_Container.Make2ValueNull()).Expect(fields, null, null, null, null); builder.WithAssertion(SupportBean_ST0_Container.Make2Value()).Expect(fields, 0, 0, 0, 0); builder.WithAssertion(SupportBean_ST0_Container.Make2Value("E1,9")).Expect(fields, 1, 1, 0, 0); builder.WithAssertion(SupportBean_ST0_Container.Make2Value("E1,1")).Expect(fields, 1, 0, 0, 0); builder.WithAssertion(SupportBean_ST0_Container.Make2Value("E1,10", "E2,9")).Expect(fields, 2, 1, 2, 0); builder.WithAssertion(SupportBean_ST0_Container.Make2Value("E1,98", "E2,97")).Expect(fields, 2, 0, 0, 2); builder.Run(env); }
public void Run(RegressionEnvironment env) { var fields = "c0,c1,c2".SplitCsv(); var builder = new SupportEvalBuilder("SupportBean_Container"); builder.WithExpression(fields[0], "Beans.sumOf(x => IntBoxed)"); builder.WithExpression(fields[1], "Beans.sumOf( (x, i) => IntBoxed + i*10)"); builder.WithExpression(fields[2], "Beans.sumOf( (x, i, s) => IntBoxed + i*10 + s*100)"); builder.WithStatementConsumer(stmt => AssertTypesAllSame(stmt.EventType, fields, typeof(int?))); builder.WithAssertion(new SupportBean_Container(null)).Expect(fields, null, null, null); builder.WithAssertion(new SupportBean_Container(EmptyList <SupportBean> .Instance)).Expect(fields, null, null, null); IList <SupportBean> listOne = new List <SupportBean>() { MakeSB("E1", 10) }; builder.WithAssertion(new SupportBean_Container(listOne)).Expect(fields, 10, 10, 110); IList <SupportBean> listTwo = new List <SupportBean>() { MakeSB("E1", 10), MakeSB("E2", 11) }; builder.WithAssertion(new SupportBean_Container(listTwo)).Expect(fields, 21, 31, 431); builder.Run(env); }
public void Run(RegressionEnvironment env) { string[] fields = "c0,c1,c2,c3,c4".SplitCsv(); SupportEvalBuilder builder = new SupportEvalBuilder("SupportBean_ST0_Container"); builder.WithExpression(fields[0], "Contained.aggregate(0, (result, item) => result + item.P00)"); builder.WithExpression(fields[1], "Contained.aggregate('', (result, item) => result || ', ' || item.Id)"); builder.WithExpression(fields[2], "Contained.aggregate('', (result, item) => result || (case when result='' then '' else ',' end) || item.Id)"); builder.WithExpression(fields[3], "Contained.aggregate(0, (result, item, i) => result + item.P00 + i*10)"); builder.WithExpression(fields[4], "Contained.aggregate(0, (result, item, i, s) => result + item.P00 + i*10 + s*100)"); builder.WithStatementConsumer( stmt => LambdaAssertionUtil.AssertTypes( stmt.EventType, fields, new[] { typeof(int?), typeof(string), typeof(string), typeof(int?), typeof(int?) })); builder.WithAssertion(SupportBean_ST0_Container.Make2Value("E1,12", "E2,11", "E2,2")) .Expect(fields, 25, ", E1, E2, E2", "E1,E2,E2", 12 + 21 + 22, 312 + 321 + 322); builder.WithAssertion(SupportBean_ST0_Container.Make2ValueNull()) .Expect(fields, null, null, null, null, null); builder.WithAssertion(SupportBean_ST0_Container.Make2Value(new string[0])) .Expect(fields, 0, "", "", 0, 0); builder.WithAssertion(SupportBean_ST0_Container.Make2Value("E1,12")) .Expect(fields, 12, ", E1", "E1", 12, 112); builder.Run(env); }
public void Run(RegressionEnvironment env) { string[] fields = "c0,c1,c2".SplitCsv(); SupportEvalBuilder builder = new SupportEvalBuilder("SupportBean_ST0_Container"); builder.WithExpression(fields[0], "Contained.arrayOf(x => x.P00)"); builder.WithExpression(fields[1], "Contained.arrayOf((x, i) => x.P00 + i*10)"); builder.WithExpression(fields[2], "Contained.arrayOf((x, i, s) => x.P00 + i*10 + s*100)"); builder.WithStatementConsumer(stmt => AssertTypesAllSame(stmt.EventType, fields, typeof(int?[]))); builder.WithAssertion(SupportBean_ST0_Container.Make2Value("E1,1", "E2,9", "E2,2")) .Expect(fields, IntArray(1, 9, 2), IntArray(1, 19, 22), IntArray(301, 319, 322)); builder.WithAssertion(SupportBean_ST0_Container.Make2ValueNull()) .Expect(fields, null, null, null); builder.WithAssertion(SupportBean_ST0_Container.Make2Value()) .Expect(fields, IntArray(), IntArray(), IntArray()); builder.WithAssertion(SupportBean_ST0_Container.Make2Value("E1,9")) .Expect(fields, IntArray(9), IntArray(9), IntArray(109)); builder.Run(env); }
public void Run(RegressionEnvironment env) { string[] fields = "c0,c1,c2".SplitCsv(); SupportEvalBuilder builder = new SupportEvalBuilder("SupportCollection"); builder.WithExpression(fields[0], "Strvals.except(Strvalstwo)"); builder.WithExpression(fields[1], "Strvals.intersect(Strvalstwo)"); builder.WithExpression(fields[2], "Strvals.union(Strvalstwo)"); builder.WithStatementConsumer(stmt => AssertTypesAllSame(stmt.EventType, fields, typeof(ICollection <object>))); builder.WithAssertion(SupportCollection.MakeString("E1,E2", "E3,E4")) .Verify("c0", val => AssertValuesArrayScalar(val, "E1", "E2")) .Verify("c1", val => AssertValuesArrayScalar(val)) .Verify("c2", val => AssertValuesArrayScalar(val, "E1", "E2", "E3", "E4")); builder.WithAssertion(SupportCollection.MakeString(null, "E3,E4")) .Verify("c0", val => AssertValuesArrayScalar(val, (object[])null)) .Verify("c1", val => AssertValuesArrayScalar(val, (object[])null)) .Verify("c2", val => AssertValuesArrayScalar(val, (object[])null)); builder.WithAssertion(SupportCollection.MakeString("", "E3,E4")) .Verify("c0", val => AssertValuesArrayScalar(val)) .Verify("c1", val => AssertValuesArrayScalar(val)) .Verify("c2", val => AssertValuesArrayScalar(val, "E3", "E4")); builder.WithAssertion(SupportCollection.MakeString("E1,E3,E5", "E3,E4")) .Verify("c0", val => AssertValuesArrayScalar(val, "E1", "E5")) .Verify("c1", val => AssertValuesArrayScalar(val, "E3")) .Verify("c2", val => AssertValuesArrayScalar(val, "E1", "E3", "E5", "E3", "E4")); builder.Run(env); }
public void Run(RegressionEnvironment env) { string[] fields = "c0,c1,c2,c3".SplitCsv(); SupportEvalBuilder builder = new SupportEvalBuilder("SupportCollection"); builder.WithExpression(fields[0], "Strvals.arrayOf()"); builder.WithExpression(fields[1], "Strvals.arrayOf(v => v)"); builder.WithExpression(fields[2], "Strvals.arrayOf( (v, i) => v || '_' || Convert.ToString(i))"); builder.WithExpression(fields[3], "Strvals.arrayOf( (v, i, s) => v || '_' || Convert.ToString(i) || '_' || Convert.ToString(s))"); builder.WithStatementConsumer(stmt => AssertTypesAllSame(stmt.EventType, fields, typeof(string[]))); builder.WithAssertion(SupportCollection.MakeString("A,B,C")) .Expect(fields, Csv("A,B,C"), Csv("A,B,C"), Csv("A_0,B_1,C_2"), Csv("A_0_3,B_1_3,C_2_3")); builder.WithAssertion(SupportCollection.MakeString("")) .Expect(fields, Csv(""), Csv(""), Csv(""), Csv("")); builder.WithAssertion(SupportCollection.MakeString("A")) .Expect(fields, Csv("A"), Csv("A"), Csv("A_0"), Csv("A_0_1")); builder.WithAssertion(SupportCollection.MakeString(null)) .Expect(fields, null, null, null, null); builder.Run(env); }
public void Run(RegressionEnvironment env) { string[] fields = "c0,c1,c2,c3".SplitCsv(); SupportEvalBuilder builder = new SupportEvalBuilder("SupportCollection"); builder.WithExpression(fields[0], "Strvals.take(2)"); builder.WithExpression(fields[1], "Strvals.take(1)"); builder.WithExpression(fields[2], "Strvals.takeLast(2)"); builder.WithExpression(fields[3], "Strvals.takeLast(1)"); builder.WithStatementConsumer(stmt => AssertTypesAllSame(stmt.EventType, fields, typeof(ICollection <object>))); builder.WithAssertion(SupportCollection.MakeString("E1,E2,E3")) .Verify("c0", val => AssertValuesArrayScalar(val, "E1", "E2")) .Verify("c1", val => AssertValuesArrayScalar(val, "E1")) .Verify("c2", val => AssertValuesArrayScalar(val, "E2", "E3")) .Verify("c3", val => AssertValuesArrayScalar(val, "E3")); builder.WithAssertion(SupportCollection.MakeString("E1,E2")) .Verify("c0", val => AssertValuesArrayScalar(val, "E1", "E2")) .Verify("c1", val => AssertValuesArrayScalar(val, "E1")) .Verify("c2", val => AssertValuesArrayScalar(val, "E1", "E2")) .Verify("c3", val => AssertValuesArrayScalar(val, "E2")); AssertSingleAndEmptySupportColl(builder, fields); builder.Run(env); }
private static void RunAssertion( RegressionEnvironment env, string lhs, string rhs, Consumer <SupportBean> one, Consumer <SupportBean> two, Consumer <SupportBean> three) { var builder = new SupportEvalBuilder("SupportBean"); var fields = "c0,c1,c2,c3".SplitCsv(); builder.WithExpression(fields[0], lhs + ">=" + rhs); builder.WithExpression(fields[1], lhs + ">" + rhs); builder.WithExpression(fields[2], lhs + "<=" + rhs); builder.WithExpression(fields[3], lhs + "<" + rhs); var beanOne = new SupportBean(); one.Invoke(beanOne); builder.WithAssertion(beanOne).Expect(fields, false, false, true, true); var beanTwo = new SupportBean(); two.Invoke(beanTwo); builder.WithAssertion(beanTwo).Expect(fields, true, false, true, false); var beanThree = new SupportBean(); three.Invoke(beanThree); builder.WithAssertion(beanThree).Expect(fields, true, true, false, false); builder.Run(env); env.UndeployAll(); }
public void Run(RegressionEnvironment env) { string[] fields = "c0,c1,c2,c3".SplitCsv(); SupportEvalBuilder builder = new SupportEvalBuilder("SupportBean_ST0_Container"); builder.WithExpression(fields[0], "Contained.orderBy( (x, i) => case when i <= 2 then P00 else i-10 end)"); builder.WithExpression(fields[1], "Contained.orderByDesc( (x, i) => case when i <= 2 then P00 else i-10 end)"); builder.WithExpression(fields[2], "Contained.orderBy( (x, i, s) => case when s <= 2 then P00 else i-10 end)"); builder.WithExpression(fields[3], "Contained.orderByDesc( (x, i, s) => case when s <= 2 then P00 else i-10 end)"); builder.WithStatementConsumer(stmt => AssertTypesAllSame(stmt.EventType, fields, typeof(ICollection <object>))); builder.WithAssertion(SupportBean_ST0_Container.Make2Value("E1,1", "E2,2")) .Verify("c0", val => AssertST0Id(val, "E1,E2")) .Verify("c1", val => AssertST0Id(val, "E2,E1")) .Verify("c2", val => AssertST0Id(val, "E1,E2")) .Verify("c3", val => AssertST0Id(val, "E2,E1")); builder.WithAssertion(SupportBean_ST0_Container.Make2Value("E1,1", "E2,2", "E3,3", "E4,4")) .Verify("c0", val => AssertST0Id(val, "E4,E1,E2,E3")) .Verify("c1", val => AssertST0Id(val, "E3,E2,E1,E4")) .Verify("c2", val => AssertST0Id(val, "E1,E2,E3,E4")) .Verify("c3", val => AssertST0Id(val, "E4,E3,E2,E1")); builder.WithAssertion(SupportBean_ST0_Container.Make2ValueNull()).Expect(fields, null, null, null, null); builder.WithAssertion(SupportBean_ST0_Container.Make2Value()) .Verify("c0", val => AssertST0Id(val, "")) .Verify("c1", val => AssertST0Id(val, "")) .Verify("c2", val => AssertST0Id(val, "")) .Verify("c3", val => AssertST0Id(val, "")); builder.Run(env); }
public void Run(RegressionEnvironment env) { var fields = "c0,c1,c2".SplitCsv(); var builder = new SupportEvalBuilder("SupportCollection"); builder.WithExpression(fields[0], "Strvals.where(x => x not like '%1%')"); builder.WithExpression(fields[1], "Strvals.where((x, i) => x not like '%1%' and i >= 1)"); builder.WithExpression(fields[2], "Strvals.where((x, i, s) => x not like '%1%' and i >= 1 and s >= 3)"); builder.WithStatementConsumer(stmt => AssertTypesAllSame(stmt.EventType, fields, typeof(ICollection<object>))); builder.WithAssertion(SupportCollection.MakeString("E1,E2,E3")) .Verify("c0", val => AssertValuesArrayScalar(val, "E2", "E3")) .Verify("c1", val => AssertValuesArrayScalar(val, "E2", "E3")) .Verify("c2", val => AssertValuesArrayScalar(val, "E2", "E3")); builder.WithAssertion(SupportCollection.MakeString("E4,E2,E1")) .Verify("c0", val => AssertValuesArrayScalar(val, "E4", "E2")) .Verify("c1", val => AssertValuesArrayScalar(val, "E2")) .Verify("c2", val => AssertValuesArrayScalar(val, "E2")); builder.WithAssertion(SupportCollection.MakeString("")) .Verify("c0", val => AssertValuesArrayScalar(val)) .Verify("c1", val => AssertValuesArrayScalar(val)) .Verify("c2", val => AssertValuesArrayScalar(val)); builder.WithAssertion(SupportCollection.MakeString("E4,E2")) .Verify("c0", val => AssertValuesArrayScalar(val, "E4", "E2")) .Verify("c1", val => AssertValuesArrayScalar(val, "E2")) .Verify("c2", val => AssertValuesArrayScalar(val)); builder.Run(env); }
public void Run(RegressionEnvironment env) { string[] fields = "c0,c1,c2".SplitCsv(); SupportEvalBuilder builder = new SupportEvalBuilder("SupportCollection"); builder.WithExpression(fields[0], "Strvals.toMap(k => k, v => extractNum(v))"); builder.WithExpression(fields[1], "Strvals.toMap((k, i) => k || '_' || Convert.ToString(i), (v, idx) => extractNum(v) + 10*idx)"); builder.WithExpression( fields[2], "Strvals.toMap((k, i, s) => k || '_' || Convert.ToString(i) || '_' || Convert.ToString(s), (v, idx, sz) => extractNum(v) + 10*idx + 100*sz)"); builder.WithStatementConsumer(stmt => AssertTypesAllSame(stmt.EventType, fields, typeof(IDictionary <object, object>))); builder.WithAssertion(SupportCollection.MakeString("E2,E1,E3")) .Verify("c0", val => CompareMap(val, "E1,E2,E3", 1, 2, 3)) .Verify("c1", val => CompareMap(val, "E1_1,E2_0,E3_2", 11, 2, 23)) .Verify("c2", val => CompareMap(val, "E1_1_3,E2_0_3,E3_2_3", 311, 302, 323)); builder.WithAssertion(SupportCollection.MakeString("E1")) .Verify("c0", val => CompareMap(val, "E1", 1)) .Verify("c1", val => CompareMap(val, "E1_0", 1)) .Verify("c2", val => CompareMap(val, "E1_0_1", 101)); builder.WithAssertion(SupportCollection.MakeString(null)) .Verify("c0", Assert.IsNull) .Verify("c1", Assert.IsNull) .Verify("c2", Assert.IsNull); builder.WithAssertion(SupportCollection.MakeString("")) .Verify("c0", val => CompareMap(val, "")) .Verify("c1", val => CompareMap(val, "")) .Verify("c2", val => CompareMap(val, "")); builder.Run(env); }
public void Run(RegressionEnvironment env) { string[] fields = "c0,c1,c2".SplitCsv(); SupportEvalBuilder builder = new SupportEvalBuilder("SupportBean_ST0_Container"); builder.WithExpression(fields[0], "Contained.toMap(c => Id, d => P00)"); builder.WithExpression(fields[1], "Contained.toMap((c, index) => Id || '_' || Convert.ToString(index), (d, index) => P00 + 10*index)"); builder.WithExpression( fields[2], "Contained.toMap((c, index, size) => Id || '_' || Convert.ToString(index) || '_' || Convert.ToString(size), (d, index, size) => P00 + 10*index + 100*size)"); builder.WithStatementConsumer(stmt => AssertTypesAllSame(stmt.EventType, fields, typeof(IDictionary <object, object>))); builder.WithAssertion(SupportBean_ST0_Container.Make2Value("E1,1", "E3,12", "E2,5")) .Verify("c0", val => CompareMap(val, "E1,E3,E2", 1, 12, 5)) .Verify("c1", val => CompareMap(val, "E1_0,E3_1,E2_2", 1, 22, 25)) .Verify("c2", val => CompareMap(val, "E1_0_3,E3_1_3,E2_2_3", 301, 322, 325)); builder.WithAssertion(SupportBean_ST0_Container.Make2Value("E1,1", "E3,4", "E2,7", "E1,2")) .Verify("c0", val => CompareMap(val, "E1,E3,E2", 2, 4, 7)) .Verify("c1", val => CompareMap(val, "E1_0,E3_1,E2_2,E1_3", 1, 14, 27, 32)) .Verify("c2", val => CompareMap(val, "E1_0_4,E3_1_4,E2_2_4,E1_3_4", 401, 414, 427, 432)); builder.WithAssertion(new SupportBean_ST0_Container(Collections.SingletonList(new SupportBean_ST0(null, null)))) .Verify("c0", val => CompareMap(val, "E1,E2,E3", null, null, null)) .Verify("c1", val => CompareMap(val, "E1,E2,E3", null, null, null)) .Verify("c2", val => CompareMap(val, "E1,E2,E3", null, null, null)); builder.Run(env); }
public void Run(RegressionEnvironment env) { string[] fields = "c0,c1".SplitCsv(); SupportEvalBuilder builder = new SupportEvalBuilder("SupportBean_ST0_Container"); builder.WithExpression(fields[0], "Contained.selectFrom( (v, i) => new {v0=v.Id,v1=i})"); builder.WithExpression(fields[1], "Contained.selectFrom( (v, i, s) => new {v0=v.Id,v1=i + 100*s})"); builder.WithStatementConsumer(stmt => AssertTypesAllSame(stmt.EventType, fields, typeof(ICollection <object>))); builder.WithAssertion(SupportBean_ST0_Container.Make3Value("E1,12,0", "E2,11,0", "E3,2,0")) .Verify( fields[0], value => AssertRows( value, new object[][] { new object[] { "E1", 0 }, new object[] { "E2", 1 }, new object[] { "E3", 2 } })) .Verify( fields[1], value => AssertRows( value, new object[][] { new object[] { "E1", 300 }, new object[] { "E2", 301 }, new object[] { "E3", 302 } })); builder.WithAssertion(SupportBean_ST0_Container.Make3Value("E4,0,1")) .Verify( fields[0], value => AssertRows( value, new object[][] { new object[] { "E4", 0 } })) .Verify( fields[1], value => AssertRows( value, new object[][] { new object[] { "E4", 100 } })); builder.WithAssertion(SupportBean_ST0_Container.Make3ValueNull()) .Verify(fields[0], value => AssertRows(value, null)) .Verify(fields[1], value => AssertRows(value, null)); builder.WithAssertion(SupportBean_ST0_Container.Make3Value()) .Verify(fields[0], value => AssertRows(value, new object[0][])) .Verify(fields[1], value => AssertRows(value, new object[0][])); builder.Run(env); }
public void Run(RegressionEnvironment env) { string[] fields = "c0,c1,c2,c3,c4,c5,c6,c7".SplitCsv(); SupportEvalBuilder builder = new SupportEvalBuilder("SupportCollection"); builder.WithExpression(fields[0], "Strvals.min(v => extractNum(v))"); builder.WithExpression(fields[1], "Strvals.max(v => extractNum(v))"); builder.WithExpression(fields[2], "Strvals.min(v => v)"); builder.WithExpression(fields[3], "Strvals.max(v => v)"); builder.WithExpression(fields[4], "Strvals.min( (v, i) => extractNum(v) + i*10)"); builder.WithExpression(fields[5], "Strvals.max( (v, i) => extractNum(v) + i*10)"); builder.WithExpression(fields[6], "Strvals.min( (v, i, s) => extractNum(v) + i*10 + s*100)"); builder.WithExpression(fields[7], "Strvals.max( (v, i, s) => extractNum(v) + i*10 + s*100)"); builder.WithStatementConsumer( stmt => AssertTypes( stmt.EventType, fields, new[] { typeof(int?), typeof(int?), typeof(string), typeof(string), typeof(int?), typeof(int?), typeof(int?), typeof(int?) })); builder.WithAssertion(SupportCollection.MakeString("E2,E1,E5,E4")).Expect(fields, 1, 5, "E1", "E5", 2, 34, 402, 434); builder.WithAssertion(SupportCollection.MakeString("E1")).Expect(fields, 1, 1, "E1", "E1", 1, 1, 101, 101); builder.WithAssertion(SupportCollection.MakeString(null)).Expect(fields, null, null, null, null, null, null, null, null); builder.WithAssertion(SupportCollection.MakeString("")).Expect(fields, null, null, null, null, null, null, null, null); builder.Run(env); }
public void Run(RegressionEnvironment env) { string[] fields = "c0,c1,c2,c3,c4,c5,c6,c7".SplitCsv(); SupportEvalBuilder builder = new SupportEvalBuilder("SupportCollection"); builder.WithExpression(fields[0], "Strvals.firstOf()"); builder.WithExpression(fields[1], "Strvals.lastOf()"); builder.WithExpression(fields[2], "Strvals.firstOf(x => x like '%1%')"); builder.WithExpression(fields[3], "Strvals.lastOf(x => x like '%1%')"); builder.WithExpression(fields[4], "Strvals.firstOf((x, i) => x like '%1%' and i >= 1)"); builder.WithExpression(fields[5], "Strvals.lastOf((x, i) => x like '%1%' and i >= 1)"); builder.WithExpression(fields[6], "Strvals.firstOf((x, i, s) => x like '%1%' and i >= 1 and s > 2)"); builder.WithExpression(fields[7], "Strvals.lastOf((x, i, s) => x like '%1%' and i >= 1 and s > 2)"); builder.WithStatementConsumer(stmt => AssertTypesAllSame(stmt.EventType, fields, typeof(string))); builder.WithAssertion(SupportCollection.MakeString("E1,E2,E3")).Expect(fields, "E1", "E3", "E1", "E1", null, null, null, null); builder.WithAssertion(SupportCollection.MakeString("E1")).Expect(fields, "E1", "E1", "E1", "E1", null, null, null, null); builder.WithAssertion(SupportCollection.MakeString("E2,E3,E4")).Expect(fields, "E2", "E4", null, null, null, null, null, null); builder.WithAssertion(SupportCollection.MakeString("")).Expect(fields, null, null, null, null, null, null, null, null); builder.WithAssertion(SupportCollection.MakeString(null)).Expect(fields, null, null, null, null, null, null, null, null); builder.WithAssertion(SupportCollection.MakeString("E5,E2,E3,A1,B1")).Expect(fields, "E5", "B1", "A1", "B1", "A1", "B1", "A1", "B1"); builder.WithAssertion(SupportCollection.MakeString("A1,B1,E5,E2,E3")).Expect(fields, "A1", "E3", "A1", "B1", "B1", "B1", "B1", "B1"); builder.WithAssertion(SupportCollection.MakeString("A1,B1")).Expect(fields, "A1", "B1", "A1", "B1", "B1", "B1", null, null); builder.Run(env); }
public void Run(RegressionEnvironment env) { var bigInteger = typeof(BigIntegerHelper).FullName; var fields = "c0,c1,c2,c3".SplitCsv(); var builder = new SupportEvalBuilder("SupportBean"); builder.WithExpression(fields[0], "{1d, 2d}.sumOf()"); builder.WithExpression(fields[1], "{" + bigInteger + ".ValueOf(1), " + bigInteger + ".ValueOf(2)}.sumOf()"); builder.WithExpression(fields[2], "{1L, 2L}.sumOf()"); builder.WithExpression(fields[3], "{1L, 2L, null}.sumOf()"); builder.WithAssertion(new SupportBean()).Expect(fields, 3d, new BigInteger(3), 3L, 3L); builder.Run(env); }
public void Run(RegressionEnvironment env) { var fields = "c0,c1".SplitCsv(); var builder = new SupportEvalBuilder("SupportCollection"); builder.WithExpression(fields[0], "Intvals.sumOf()"); builder.WithExpression(fields[1], "Bdvals.sumOf()"); builder.WithStatementConsumer(stmt => AssertTypes(stmt.EventType, fields, new[] { typeof(int?), typeof(decimal?) })); builder.WithAssertion(SupportCollection.MakeNumeric("1,4,5")).Expect(fields, 1 + 4 + 5, 1m + 4m + 5m); builder.WithAssertion(SupportCollection.MakeNumeric("3,4")).Expect(fields, 3 + 4, 3m + 4m); builder.WithAssertion(SupportCollection.MakeNumeric("3")).Expect(fields, 3, 3m); builder.WithAssertion(SupportCollection.MakeNumeric("")).Expect(fields, null, null); builder.WithAssertion(SupportCollection.MakeNumeric(null)).Expect(fields, null, null); builder.Run(env); }
public void Run(RegressionEnvironment env) { string[] fields = "c0".SplitCsv(); SupportEvalBuilder builder = new SupportEvalBuilder("SupportBean_ST0_Container"); builder.WithExpression(fields[0], "Contained.reverse()"); builder.WithStatementConsumer(stmt => AssertTypesAllSame(stmt.EventType, fields, typeof(ICollection <object>))); builder.WithAssertion(SupportBean_ST0_Container.Make2Value("E1,1", "E2,9", "E3,1")) .Verify("c0", val => AssertST0Id(val, "E3,E2,E1")); builder.WithAssertion(SupportBean_ST0_Container.Make2Value("E2,9", "E1,1")) .Verify("c0", val => AssertST0Id(val, "E1,E2")); builder.WithAssertion(SupportBean_ST0_Container.Make2Value("E1,1")) .Verify("c0", val => AssertST0Id(val, "E1")); builder.WithAssertion(SupportBean_ST0_Container.Make2ValueNull()) .Verify("c0", val => AssertST0Id(val, null)); builder.WithAssertion(SupportBean_ST0_Container.Make2Value()) .Verify("c0", val => AssertST0Id(val, "")); builder.Run(env); }
public void Run(RegressionEnvironment env) { var fields = "c0,c1,c2".SplitCsv(); var builder = new SupportEvalBuilder("SupportBean_ST0_Container"); builder.WithExpression(fields[0], "Contained.where(x => P00 = 9)"); builder.WithExpression(fields[1], "Contained.where((x, i) => x.P00 = 9 and i >= 1)"); builder.WithExpression(fields[2], "Contained.where((x, i, s) => x.P00 = 9 and i >= 1 and s > 2)"); builder.WithStatementConsumer(stmt => AssertTypesAllSame(stmt.EventType, fields, typeof(ICollection<object>))); builder.WithAssertion(SupportBean_ST0_Container.Make2Value("E1,1", "E2,9", "E3,1")) .Verify("c0", val => AssertST0Id(val, "E2")) .Verify("c1", val => AssertST0Id(val, "E2")) .Verify("c2", val => AssertST0Id(val, "E2")); builder.WithAssertion(SupportBean_ST0_Container.Make2Value("E1,9", "E2,1", "E3,1")) .Verify("c0", val => AssertST0Id(val, "E1")) .Verify("c1", val => AssertST0Id(val, "")) .Verify("c2", val => AssertST0Id(val, "")); builder.WithAssertion(SupportBean_ST0_Container.Make2Value("E1,1", "E2,1", "E3,9")) .Verify("c0", val => AssertST0Id(val, "E3")) .Verify("c1", val => AssertST0Id(val, "E3")) .Verify("c2", val => AssertST0Id(val, "E3")); builder.WithAssertion(SupportBean_ST0_Container.Make2Value("E1,9", "E3,9")) .Verify("c0", val => AssertST0Id(val, "E1,E3")) .Verify("c1", val => AssertST0Id(val, "E3")) .Verify("c2", val => AssertST0Id(val, "")); builder.WithAssertion(SupportBean_ST0_Container.Make2Value("E1,1", "E2,9", "E3,1", "E4,9")) .Verify("c0", val => AssertST0Id(val, "E2,E4")) .Verify("c1", val => AssertST0Id(val, "E2,E4")) .Verify("c2", val => AssertST0Id(val, "E2,E4")); builder.WithAssertion(SupportBean_ST0_Container.Make2ValueNull()) .Verify("c0", Assert.IsNull) .Verify("c1", Assert.IsNull) .Verify("c2", Assert.IsNull); builder.WithAssertion(SupportBean_ST0_Container.Make2Value()) .Verify("c0", val => AssertST0Id(val, "")) .Verify("c1", val => AssertST0Id(val, "")) .Verify("c2", val => AssertST0Id(val, "")); builder.Run(env); }
public void Run(RegressionEnvironment env) { var fields = "c0,c1,c2,c3,c4,c5,c6,c7".SplitCsv(); var builder = new SupportEvalBuilder("SupportBean_Container"); builder.WithExpression(fields[0], "Beans.average(x => IntBoxed)"); builder.WithExpression(fields[1], "Beans.average(x => DoubleBoxed)"); builder.WithExpression(fields[2], "Beans.average(x => LongBoxed)"); builder.WithExpression(fields[3], "Beans.average(x => DecimalBoxed)"); builder.WithExpression(fields[4], "Beans.average( (x, i) => IntBoxed + i*10)"); builder.WithExpression(fields[5], "Beans.average( (x, i) => DecimalBoxed + i*10)"); builder.WithExpression(fields[6], "Beans.average( (x, i, s) => IntBoxed + i*10 + s*100)"); builder.WithExpression(fields[7], "Beans.average( (x, i, s) => DecimalBoxed + i*10 + s*100)"); builder.WithStatementConsumer( stmt => AssertTypes( stmt.EventType, fields, new[] { typeof(double?), typeof(double?), typeof(double?), typeof(decimal?), typeof(double?), typeof(decimal?), typeof(double?), typeof(decimal?) })); builder.WithAssertion(new SupportBean_Container(null)) .Expect(fields, null, null, null, null, null, null, null, null); builder.WithAssertion(new SupportBean_Container(EmptyList <SupportBean> .Instance)) .Expect(fields, null, null, null, null, null, null, null, null); var listOne = new List <SupportBean>() { Make(2, 3d, 4L, 5) }; builder.WithAssertion(new SupportBean_Container(listOne)) .Expect(fields, 2d, 3d, 4d, 5.0m, 2d, 5.0m, 102d, 105.0m); var listTwo = new List <SupportBean>() { Make(2, 3d, 4L, 5), Make(4, 6d, 8L, 10) }; builder.WithAssertion(new SupportBean_Container(listTwo)) .Expect( fields, (2 + 4) / 2d, (3d + 6d) / 2d, (4L + 8L) / 2d, (5m + 10m) / 2m, (2 + 14) / 2d, (5m + 20m) / 2m, (202 + 214) / 2d, (205m + 220m) / 2m); builder.Run(env); }
public void Run(RegressionEnvironment env) { string[] fields = "c0,c1".SplitCsv(); SupportEvalBuilder builder = new SupportEvalBuilder("SupportCollection"); builder.WithExpression(fields[0], "Strvals.orderBy()"); builder.WithExpression(fields[1], "Strvals.orderByDesc()"); builder.WithStatementConsumer(stmt => AssertTypesAllSame(stmt.EventType, fields, typeof(ICollection <object>))); builder.WithAssertion(SupportCollection.MakeString("E2,E1,E5,E4")) .Verify("c0", val => AssertValuesArrayScalar(val, "E1", "E2", "E4", "E5")) .Verify("c1", val => AssertValuesArrayScalar(val, "E5", "E4", "E2", "E1")); LambdaAssertionUtil.AssertSingleAndEmptySupportColl(builder, fields); builder.Run(env); }
public void Run(RegressionEnvironment env) { var fields = "c0,c1".SplitCsv(); var builder = new SupportEvalBuilder("SupportCollection"); builder.WithExpression(fields[0], "Intvals.average()"); builder.WithExpression(fields[1], "Bdvals.average()"); builder.WithStatementConsumer(stmt => AssertTypes(env.Statement("s0").EventType, fields, new[] { typeof(double?), typeof(decimal?) })); builder.WithAssertion(SupportCollection.MakeNumeric("1,2,3")).Expect(fields, 2d, 2m); builder.WithAssertion(SupportCollection.MakeNumeric("1,null,3")).Expect(fields, 2d, 2m); builder.WithAssertion(SupportCollection.MakeNumeric("4")).Expect(fields, 4d, 4m); builder.Run(env); }
public void Run(RegressionEnvironment env) { var fields = "c0,c1,c2,c3".SplitCsv(); var builder = new SupportEvalBuilder("SupportCollection"); builder.WithExpression(fields[0], "Strvals.sumOf(v => extractNum(v))"); builder.WithExpression(fields[1], "Strvals.sumOf(v => extractDecimal(v))"); builder.WithExpression(fields[2], "Strvals.sumOf( (v, i) => extractNum(v) + i*10)"); builder.WithExpression(fields[3], "Strvals.sumOf( (v, i, s) => extractNum(v) + i*10 + s*100)"); builder.WithStatementConsumer( stmt => AssertTypes(env.Statement("s0").EventType, fields, new[] { typeof(int?), typeof(decimal?), typeof(int?), typeof(int?) })); builder.WithAssertion(SupportCollection.MakeString("E2,E1,E5,E4")) .Expect(fields, 2 + 1 + 5 + 4, 2m + 1m + 5m + 4m, 2 + 11 + 25 + 34, 402 + 411 + 425 + 434); builder.WithAssertion(SupportCollection.MakeString("E1")).Expect(fields, 1, 1m, 1, 101); builder.WithAssertion(SupportCollection.MakeString(null)).Expect(fields, null, null, null, null); builder.WithAssertion(SupportCollection.MakeString("")).Expect(fields, null, null, null, null); builder.Run(env); }
public void Run(RegressionEnvironment env) { string[] fields = "c0,c1".SplitCsv(); SupportEvalBuilder builder = new SupportEvalBuilder("SupportCollection"); builder.WithExpression(fields[0], "Strvals.mostFrequent()"); builder.WithExpression(fields[1], "Strvals.leastFrequent()"); builder.WithStatementConsumer(stmt => AssertTypesAllSame(stmt.EventType, fields, typeof(string))); builder.WithAssertion(SupportCollection.MakeString("E2,E1,E2,E1,E3,E3,E4,E3")).Expect(fields, "E3", "E4"); builder.WithAssertion(SupportCollection.MakeString("E1")).Expect(fields, "E1", "E1"); builder.WithAssertion(SupportCollection.MakeString(null)).Expect(fields, null, null); builder.WithAssertion(SupportCollection.MakeString("")).Expect(fields, null, null); builder.Run(env); }
public void Run(RegressionEnvironment env) { string[] fields = "c0,c1".SplitCsv(); SupportEvalBuilder builder = new SupportEvalBuilder("SupportBean_ST0_Container"); builder.WithExpression(fields[0], "Contained.firstOf().P00"); builder.WithExpression(fields[1], "Contained.lastOf().P00"); builder.WithStatementConsumer(stmt => AssertTypesAllSame(stmt.EventType, fields, typeof(int?))); builder.WithAssertion(SupportBean_ST0_Container.Make2Value("E1,1", "E2,9", "E3,3")).Expect(fields, 1, 3); builder.WithAssertion(SupportBean_ST0_Container.Make2Value("E1,1")).Expect(fields, 1, 1); builder.WithAssertion(SupportBean_ST0_Container.Make2ValueNull()).Expect(fields, null, null); builder.WithAssertion(SupportBean_ST0_Container.Make2Value()).Expect(fields, null, null); builder.Run(env); }
public void Run(RegressionEnvironment env) { string[] fields = "c0,c1,c2".SplitCsv(); SupportEvalBuilder builder = new SupportEvalBuilder("SupportBean_ST0_Container"); builder.WithExpression(fields[0], "Contained.except(ContainedTwo)"); builder.WithExpression(fields[1], "Contained.intersect(ContainedTwo)"); builder.WithExpression(fields[2], "Contained.union(ContainedTwo)"); builder.WithStatementConsumer(stmt => AssertTypesAllSame(stmt.EventType, fields, typeof(ICollection <object>))); IList <SupportBean_ST0> first = SupportBean_ST0_Container.Make2ValueList("E1,1", "E2,10", "E3,1", "E4,10", "E5,11"); IList <SupportBean_ST0> second = SupportBean_ST0_Container.Make2ValueList("E1,1", "E3,1", "E4,10"); builder.WithAssertion(new SupportBean_ST0_Container(first, second)) .Verify("c0", val => AssertST0Id(val, "E2,E5")) .Verify("c1", val => AssertST0Id(val, "E1,E3,E4")) .Verify("c2", val => AssertST0Id(val, "E1,E2,E3,E4,E5,E1,E3,E4")); builder.Run(env); }
public void Run(RegressionEnvironment env) { string[] fields = "c0,c1,c2,c3,c4,c5".SplitCsv(); SupportEvalBuilder builder = new SupportEvalBuilder("SupportBean_ST0_Container"); builder.WithExpression(fields[0], "Contained.mostFrequent(x => P00)"); builder.WithExpression(fields[1], "Contained.leastFrequent(x => P00)"); builder.WithExpression(fields[2], "Contained.mostFrequent( (x, i) => P00 + i*2)"); builder.WithExpression(fields[3], "Contained.leastFrequent( (x, i) => P00 + i*2)"); builder.WithExpression(fields[4], "Contained.mostFrequent( (x, i, s) => P00 + i*2 + s*4)"); builder.WithExpression(fields[5], "Contained.leastFrequent( (x, i, s) => P00 + i*2 + s*4)"); builder.WithStatementConsumer(stmt => AssertTypesAllSame(stmt.EventType, fields, typeof(int?))); SupportBean_ST0_Container bean = SupportBean_ST0_Container.Make2Value("E1,12", "E2,11", "E2,2", "E3,12"); builder.WithAssertion(bean).Expect(fields, 12, 11, 12, 12, 28, 28); bean = SupportBean_ST0_Container.Make2Value("E1,12"); builder.WithAssertion(bean).Expect(fields, 12, 12, 12, 12, 16, 16); bean = SupportBean_ST0_Container.Make2Value("E1,12", "E2,11", "E2,2", "E3,12", "E1,12", "E2,11", "E3,11"); builder.WithAssertion(bean).Expect(fields, 12, 2, 12, 12, 40, 40); bean = SupportBean_ST0_Container.Make2Value("E2,11", "E1,12", "E2,15", "E3,12", "E1,12", "E2,11", "E3,11"); builder.WithAssertion(bean).Expect(fields, 11, 15, 11, 11, 39, 39); builder.WithAssertion(SupportBean_ST0_Container.Make2ValueNull()).Expect(fields, null, null, null, null, null, null); builder.WithAssertion(SupportBean_ST0_Container.Make2Value()).Expect(fields, null, null, null, null, null, null); builder.Run(env); }
public void Run(RegressionEnvironment env) { string[] fields = "c0,c1,c2,c3,c4,c5".SplitCsv(); SupportEvalBuilder builder = new SupportEvalBuilder("SupportCollection"); builder.WithExpression(fields[0], "Strvals.orderBy(v => extractNum(v))"); builder.WithExpression(fields[1], "Strvals.orderByDesc(v => extractNum(v))"); builder.WithExpression(fields[2], "Strvals.orderBy( (v, i) => case when i <= 2 then extractNum(v) else i-10 end)"); builder.WithExpression(fields[3], "Strvals.orderByDesc( (v, i) => case when i <= 2 then extractNum(v) else i-10 end)"); builder.WithExpression(fields[4], "Strvals.orderBy( (v, i, s) => case when s <= 2 then extractNum(v) else i-10 end)"); builder.WithExpression(fields[5], "Strvals.orderByDesc( (v, i, s) => case when s <= 2 then extractNum(v) else i-10 end)"); builder.WithStatementConsumer(stmt => AssertTypesAllSame(stmt.EventType, fields, typeof(ICollection <object>))); builder.WithAssertion(SupportCollection.MakeString("E2,E1,E5,E4")) .Verify("c0", val => AssertValuesArrayScalar(val, "E1", "E2", "E4", "E5")) .Verify("c1", val => AssertValuesArrayScalar(val, "E5", "E4", "E2", "E1")) .Verify("c2", val => AssertValuesArrayScalar(val, "E4", "E1", "E2", "E5")) .Verify("c3", val => AssertValuesArrayScalar(val, "E5", "E2", "E1", "E4")) .Verify("c4", val => AssertValuesArrayScalar(val, "E2", "E1", "E5", "E4")) .Verify("c5", val => AssertValuesArrayScalar(val, "E4", "E5", "E1", "E2")); builder.WithAssertion(SupportCollection.MakeString("E2,E1")) .Verify("c0", val => AssertValuesArrayScalar(val, "E1", "E2")) .Verify("c1", val => AssertValuesArrayScalar(val, "E2", "E1")) .Verify("c2", val => AssertValuesArrayScalar(val, "E1", "E2")) .Verify("c3", val => AssertValuesArrayScalar(val, "E2", "E1")) .Verify("c4", val => AssertValuesArrayScalar(val, "E1", "E2")) .Verify("c5", val => AssertValuesArrayScalar(val, "E2", "E1")); LambdaAssertionUtil.AssertSingleAndEmptySupportColl(builder, fields); builder.Run(env); }