Browse Source

Test to ensure that range variables are not in scope for join equals expression, renamed method.

newNRvisualizers
Erik Källén 13 years ago
parent
commit
b0f16b2c6f
  1. 2
      ICSharpCode.NRefactory.CSharp/QueryExpressionExpander.cs
  2. 65
      ICSharpCode.NRefactory.Tests/CSharp/QueryExpressionExpanderTests.cs

2
ICSharpCode.NRefactory.CSharp/QueryExpressionExpander.cs

@ -334,7 +334,7 @@ namespace ICSharpCode.NRefactory.CSharp { @@ -334,7 +334,7 @@ namespace ICSharpCode.NRefactory.CSharp {
/// </summary>
/// <param name="node"></param>
/// <returns></returns>
public QueryExpressionExpansionResult ExpandQueryPattern(AstNode node) {
public QueryExpressionExpansionResult ExpandQueryExpression(AstNode node) {
var visitor = new Visitor();
var astNode = node.AcceptVisitor(visitor);
if (astNode != null) {

65
ICSharpCode.NRefactory.Tests/CSharp/QueryExpressionExpanderTests.cs

@ -37,7 +37,7 @@ namespace ICSharpCode.NRefactory.CSharp { @@ -37,7 +37,7 @@ namespace ICSharpCode.NRefactory.CSharp {
[Test]
public void QueryExpressionWithFromAndSelectWorks() {
var node = ParseUtilCSharp.ParseExpression<QueryExpression>("from a in args select int.Parse(a)");
var actual = new QueryExpressionExpander().ExpandQueryPattern(node);
var actual = new QueryExpressionExpander().ExpandQueryExpression(node);
AssertCorrect(actual.AstNode, "args.Select(a => int.Parse(a))");
dynamic astNode = actual.AstNode;
AssertLookupCorrect(actual.RangeVariables, new[] { Tuple.Create(new TextLocation(1, 6), (AstNode)ElementAt(ElementAt(astNode.Arguments, 0).Parameters, 0).NameToken) });
@ -47,7 +47,7 @@ namespace ICSharpCode.NRefactory.CSharp { @@ -47,7 +47,7 @@ namespace ICSharpCode.NRefactory.CSharp {
[Test]
public void QueryExpressionWithSingleFromAndExplicitTypeWorks() {
var node = ParseUtilCSharp.ParseExpression<QueryExpression>("from object a in args select int.Parse(a)");
var actual = new QueryExpressionExpander().ExpandQueryPattern(node);
var actual = new QueryExpressionExpander().ExpandQueryExpression(node);
AssertCorrect(actual.AstNode, "args.Cast<object>().Select(a => int.Parse(a))");
dynamic astNode = actual.AstNode;
AssertLookupCorrect(actual.RangeVariables, new[] { Tuple.Create(new TextLocation(1, 13), (AstNode)ElementAt(ElementAt(astNode.Arguments, 0).Parameters, 0).NameToken) });
@ -57,7 +57,7 @@ namespace ICSharpCode.NRefactory.CSharp { @@ -57,7 +57,7 @@ namespace ICSharpCode.NRefactory.CSharp {
[Test]
public void QueryExpressionWithLetWorks() {
var node = ParseUtilCSharp.ParseExpression<QueryExpression>("from a in args let b = int.Parse(a) select a + b.ToString()");
var actual = new QueryExpressionExpander().ExpandQueryPattern(node);
var actual = new QueryExpressionExpander().ExpandQueryExpression(node);
AssertCorrect(actual.AstNode, "args.Select(a => new { a, b = int.Parse(a) }).Select(x0 => x0.a + x0.b.ToString())");
dynamic astNode = actual.AstNode;
AssertLookupCorrect(actual.RangeVariables, new[] {
@ -74,7 +74,7 @@ namespace ICSharpCode.NRefactory.CSharp { @@ -74,7 +74,7 @@ namespace ICSharpCode.NRefactory.CSharp {
[Test]
public void QueryExpressionWithTwoLetsWorks() {
var node = ParseUtilCSharp.ParseExpression<QueryExpression>("from a in args let b = int.Parse(a) let c = b + 1 select a + b.ToString() + c.ToString()");
var actual = new QueryExpressionExpander().ExpandQueryPattern(node);
var actual = new QueryExpressionExpander().ExpandQueryExpression(node);
AssertCorrect(actual.AstNode, "args.Select(a => new { a, b = int.Parse(a) }).Select(x0 => new { x0, c = x0.b + 1 }).Select(x1 => x1.x0.a + x1.x0.b.ToString() + x1.c.ToString())");
dynamic astNode = actual.AstNode;
AssertLookupCorrect(actual.RangeVariables, new[] {
@ -93,7 +93,7 @@ namespace ICSharpCode.NRefactory.CSharp { @@ -93,7 +93,7 @@ namespace ICSharpCode.NRefactory.CSharp {
[Test]
public void TwoFromClausesFollowedBySelectWorks() {
var node = ParseUtilCSharp.ParseExpression<QueryExpression>("from i in arr1 from j in arr2 select i + j");
var actual = new QueryExpressionExpander().ExpandQueryPattern(node);
var actual = new QueryExpressionExpander().ExpandQueryExpression(node);
AssertCorrect(actual.AstNode, "arr1.SelectMany(i => arr2, (i, j) => i + j)");
dynamic astNode = actual.AstNode;
AssertLookupCorrect(actual.RangeVariables, new[] {
@ -110,7 +110,7 @@ namespace ICSharpCode.NRefactory.CSharp { @@ -110,7 +110,7 @@ namespace ICSharpCode.NRefactory.CSharp {
[Test]
public void SelectManyFollowedBySelectWorksWhenTheTargetIsTransparentAndTheCollectionsAreCorrelated() {
var node = ParseUtilCSharp.ParseExpression<QueryExpression>("from i in outer let j = F(i) from k in j.Result select i + j + k");
var actual = new QueryExpressionExpander().ExpandQueryPattern(node);
var actual = new QueryExpressionExpander().ExpandQueryExpression(node);
AssertCorrect(actual.AstNode, "outer.Select(i => new { i, j = F(i) }).SelectMany(x0 => x0.j.Result, (x1, k) => x1.i + x1.j + k)");
dynamic astNode = actual.AstNode;
AssertLookupCorrect(actual.RangeVariables, new[] {
@ -129,7 +129,7 @@ namespace ICSharpCode.NRefactory.CSharp { @@ -129,7 +129,7 @@ namespace ICSharpCode.NRefactory.CSharp {
[Test]
public void SelectManyFollowedByLetWorksWhenTheTargetIsTransparentAndTheCollectionsAreCorrelated() {
var node = ParseUtilCSharp.ParseExpression<QueryExpression>("from i in outer let j = F(i) from k in j.Result let l = i + j + k select i + j + k + l");
var actual = new QueryExpressionExpander().ExpandQueryPattern(node);
var actual = new QueryExpressionExpander().ExpandQueryExpression(node);
AssertCorrect(actual.AstNode, "outer.Select(i => new { i, j = F(i) }).SelectMany(x0 => x0.j.Result, (x1, k) => new { x1, k }).Select(x2 => new { x2, l = x2.x1.i + x2.x1.j + x2.k }).Select(x3 => x3.x2.x1.i + x3.x2.x1.j + x3.x2.k + x3.l)");
dynamic astNode = actual.AstNode;
AssertLookupCorrect(actual.RangeVariables, new[] {
@ -150,7 +150,7 @@ namespace ICSharpCode.NRefactory.CSharp { @@ -150,7 +150,7 @@ namespace ICSharpCode.NRefactory.CSharp {
[Test]
public void TwoFromClausesFollowedByLetWorks() {
var node = ParseUtilCSharp.ParseExpression<QueryExpression>("from i in arr1 from j in arr2 let k = i + j select i + j + k");
var actual = new QueryExpressionExpander().ExpandQueryPattern(node);
var actual = new QueryExpressionExpander().ExpandQueryExpression(node);
AssertCorrect(actual.AstNode, "arr1.SelectMany(i => arr2, (i, j) => new { i, j }).Select(x0 => new { x0, k = x0.i + x0.j }).Select(x1 => x1.x0.i + x1.x0.j + x1.k)");
dynamic astNode = actual.AstNode;
AssertLookupCorrect(actual.RangeVariables, new[] {
@ -169,7 +169,7 @@ namespace ICSharpCode.NRefactory.CSharp { @@ -169,7 +169,7 @@ namespace ICSharpCode.NRefactory.CSharp {
[Test]
public void ThreeFromClausesFollowedBySelectWorks() {
var node = ParseUtilCSharp.ParseExpression<QueryExpression>("from i in arr1 from j in arr2 from k in arr3 select i + j + k");
var actual = new QueryExpressionExpander().ExpandQueryPattern(node);
var actual = new QueryExpressionExpander().ExpandQueryExpression(node);
AssertCorrect(actual.AstNode, "arr1.SelectMany(i => arr2, (i, j) => new { i, j }).SelectMany(x0 => arr3, (x1, k) => x1.i + x1.j + k)");
dynamic astNode = actual.AstNode;
AssertLookupCorrect(actual.RangeVariables, new[] {
@ -188,7 +188,7 @@ namespace ICSharpCode.NRefactory.CSharp { @@ -188,7 +188,7 @@ namespace ICSharpCode.NRefactory.CSharp {
[Test]
public void GroupByWithSimpleValue() {
var node = ParseUtilCSharp.ParseExpression<QueryExpression>("from i in arr group i by i.field");
var actual = new QueryExpressionExpander().ExpandQueryPattern(node);
var actual = new QueryExpressionExpander().ExpandQueryExpression(node);
AssertCorrect(actual.AstNode, "arr.GroupBy(i => i.field)");
dynamic astNode = actual.AstNode;
AssertLookupCorrect(actual.RangeVariables, new[] {
@ -203,7 +203,7 @@ namespace ICSharpCode.NRefactory.CSharp { @@ -203,7 +203,7 @@ namespace ICSharpCode.NRefactory.CSharp {
[Test]
public void GroupByWithProjectedValue() {
var node = ParseUtilCSharp.ParseExpression<QueryExpression>("from i in arr group i.something by i.field");
var actual = new QueryExpressionExpander().ExpandQueryPattern(node);
var actual = new QueryExpressionExpander().ExpandQueryExpression(node);
AssertCorrect(actual.AstNode, "arr.GroupBy(i => i.field, i => i.something)");
dynamic astNode = actual.AstNode;
AssertLookupCorrect(actual.RangeVariables, new[] {
@ -218,7 +218,7 @@ namespace ICSharpCode.NRefactory.CSharp { @@ -218,7 +218,7 @@ namespace ICSharpCode.NRefactory.CSharp {
[Test]
public void GroupByWhenThereIsATransparentIdentifer() {
var node = ParseUtilCSharp.ParseExpression<QueryExpression>("from i in arr let j = F(i) group i by i.field");
var actual = new QueryExpressionExpander().ExpandQueryPattern(node);
var actual = new QueryExpressionExpander().ExpandQueryExpression(node);
AssertCorrect(actual.AstNode, "arr.Select(i => new { i, j = F(i) }).GroupBy(x0 => x0.i.field, x1 => x1.i)");
dynamic astNode = actual.AstNode;
AssertLookupCorrect(actual.RangeVariables, new[] {
@ -235,7 +235,7 @@ namespace ICSharpCode.NRefactory.CSharp { @@ -235,7 +235,7 @@ namespace ICSharpCode.NRefactory.CSharp {
[Test]
public void JoinFollowedBySelect() {
var node = ParseUtilCSharp.ParseExpression<QueryExpression>("from i in arr1 join j in arr2 on i.keyi equals j.keyj select i + j");
var actual = new QueryExpressionExpander().ExpandQueryPattern(node);
var actual = new QueryExpressionExpander().ExpandQueryExpression(node);
AssertCorrect(actual.AstNode, "arr1.Join(arr2, i => i.keyi, j => j.keyj, (i, j) => i + j)");
dynamic astNode = actual.AstNode;
AssertLookupCorrect(actual.RangeVariables, new[] {
@ -252,7 +252,7 @@ namespace ICSharpCode.NRefactory.CSharp { @@ -252,7 +252,7 @@ namespace ICSharpCode.NRefactory.CSharp {
[Test]
public void JoinFollowedByLet() {
var node = ParseUtilCSharp.ParseExpression<QueryExpression>("from i in arr1 join j in arr2 on i.keyi equals j.keyj let k = i + j select i + j + k");
var actual = new QueryExpressionExpander().ExpandQueryPattern(node);
var actual = new QueryExpressionExpander().ExpandQueryExpression(node);
AssertCorrect(actual.AstNode, "arr1.Join(arr2, i => i.keyi, j => j.keyj, (i, j) => new { i, j }).Select(x0 => new { x0, k = x0.i + x0.j }).Select(x1 => x1.x0.i + x1.x0.j + x1.k)");
dynamic astNode = actual.AstNode;
AssertLookupCorrect(actual.RangeVariables, new[] {
@ -271,7 +271,7 @@ namespace ICSharpCode.NRefactory.CSharp { @@ -271,7 +271,7 @@ namespace ICSharpCode.NRefactory.CSharp {
[Test]
public void JoinFollowedBySelectWhenThereIsATransparentIdentifier() {
var node = ParseUtilCSharp.ParseExpression<QueryExpression>("from i in arr1 let j = F(i) join k in arr2 on j.keyj equals k.keyk select i + j + k");
var actual = new QueryExpressionExpander().ExpandQueryPattern(node);
var actual = new QueryExpressionExpander().ExpandQueryExpression(node);
AssertCorrect(actual.AstNode, "arr1.Select(i => new { i, j = F(i) }).Join(arr2, x0 => x0.j.keyj, k => k.keyk, (x1, k) => x1.i + x1.j + k)");
dynamic astNode = actual.AstNode;
AssertLookupCorrect(actual.RangeVariables, new[] {
@ -290,7 +290,7 @@ namespace ICSharpCode.NRefactory.CSharp { @@ -290,7 +290,7 @@ namespace ICSharpCode.NRefactory.CSharp {
[Test]
public void GroupJoinFollowedBySelect() {
var node = ParseUtilCSharp.ParseExpression<QueryExpression>("from i in arr1 join j in arr2 on i.keyi equals j.keyj into g select F(i, g)");
var actual = new QueryExpressionExpander().ExpandQueryPattern(node);
var actual = new QueryExpressionExpander().ExpandQueryExpression(node);
AssertCorrect(actual.AstNode, "arr1.GroupJoin(arr2, i => i.keyi, j => j.keyj, (i, g) => F(i, g))");
dynamic astNode = actual.AstNode;
AssertLookupCorrect(actual.RangeVariables, new[] {
@ -307,7 +307,7 @@ namespace ICSharpCode.NRefactory.CSharp { @@ -307,7 +307,7 @@ namespace ICSharpCode.NRefactory.CSharp {
[Test]
public void GroupJoinFollowedByLet() {
var node = ParseUtilCSharp.ParseExpression<QueryExpression>("from i in arr1 join j in arr2 on i.keyi equals j.keyj into g let k = i + g select i + g + k");
var actual = new QueryExpressionExpander().ExpandQueryPattern(node);
var actual = new QueryExpressionExpander().ExpandQueryExpression(node);
AssertCorrect(actual.AstNode, "arr1.GroupJoin(arr2, i => i.keyi, j => j.keyj, (i, g) => new { i, g }).Select(x0 => new { x0, k = x0.i + x0.g }).Select(x1 => x1.x0.i + x1.x0.g + x1.k)");
dynamic astNode = actual.AstNode;
AssertLookupCorrect(actual.RangeVariables, new[] {
@ -326,7 +326,7 @@ namespace ICSharpCode.NRefactory.CSharp { @@ -326,7 +326,7 @@ namespace ICSharpCode.NRefactory.CSharp {
[Test]
public void GroupJoinFollowedBySelectWhenThereIsATransparentIdentifier() {
var node = ParseUtilCSharp.ParseExpression<QueryExpression>("from i in arr1 let j = F(i) join k in arr2 on j.keyj equals k.keyk into g select F(i, j, g)");
var actual = new QueryExpressionExpander().ExpandQueryPattern(node);
var actual = new QueryExpressionExpander().ExpandQueryExpression(node);
AssertCorrect(actual.AstNode, "arr1.Select(i => new { i, j = F(i) }).GroupJoin(arr2, x0 => x0.j.keyj, k => k.keyk, (x1, g) => F(x1.i, x1.j, g))");
dynamic astNode = actual.AstNode;
AssertLookupCorrect(actual.RangeVariables, new[] {
@ -345,7 +345,7 @@ namespace ICSharpCode.NRefactory.CSharp { @@ -345,7 +345,7 @@ namespace ICSharpCode.NRefactory.CSharp {
[Test]
public void WhereWorks() {
var node = ParseUtilCSharp.ParseExpression<QueryExpression>("from i in arr1 where i > 5 select i + 1");
var actual = new QueryExpressionExpander().ExpandQueryPattern(node);
var actual = new QueryExpressionExpander().ExpandQueryExpression(node);
AssertCorrect(actual.AstNode, "arr1.Where(i => i > 5).Select(i => i + 1)");
dynamic astNode = actual.AstNode;
AssertLookupCorrect(actual.RangeVariables, new[] {
@ -361,7 +361,7 @@ namespace ICSharpCode.NRefactory.CSharp { @@ -361,7 +361,7 @@ namespace ICSharpCode.NRefactory.CSharp {
[Test]
public void WhereWorksWhenThereIsATransparentIdentifier() {
var node = ParseUtilCSharp.ParseExpression<QueryExpression>("from i in arr1 let j = i + 1 where i > j select i + j");
var actual = new QueryExpressionExpander().ExpandQueryPattern(node);
var actual = new QueryExpressionExpander().ExpandQueryExpression(node);
AssertCorrect(actual.AstNode, "arr1.Select(i => new { i, j = i + 1 }).Where(x0 => x0.i > x0.j).Select(x1 => x1.i + x1.j)");
dynamic astNode = actual.AstNode;
AssertLookupCorrect(actual.RangeVariables, new[] {
@ -379,7 +379,7 @@ namespace ICSharpCode.NRefactory.CSharp { @@ -379,7 +379,7 @@ namespace ICSharpCode.NRefactory.CSharp {
[Test]
public void TrivialSelectIsEliminatedAfterWhere() {
var node = ParseUtilCSharp.ParseExpression<QueryExpression>("from i in arr1 where i > 5 select i");
var actual = new QueryExpressionExpander().ExpandQueryPattern(node);
var actual = new QueryExpressionExpander().ExpandQueryExpression(node);
AssertCorrect(actual.AstNode, "arr1.Where(i => i > 5)");
dynamic astNode = actual.AstNode;
AssertLookupCorrect(actual.RangeVariables, new[] {
@ -395,7 +395,7 @@ namespace ICSharpCode.NRefactory.CSharp { @@ -395,7 +395,7 @@ namespace ICSharpCode.NRefactory.CSharp {
[Test]
public void TrivialSelectIsNotEliminatingWhenTheOnlyOperation() {
var node = ParseUtilCSharp.ParseExpression<QueryExpression>("from i in arr1 select i");
var actual = new QueryExpressionExpander().ExpandQueryPattern(node);
var actual = new QueryExpressionExpander().ExpandQueryExpression(node);
AssertCorrect(actual.AstNode, "arr1.Select(i => i)");
dynamic astNode = actual.AstNode;
AssertLookupCorrect(actual.RangeVariables, new[] {
@ -410,7 +410,7 @@ namespace ICSharpCode.NRefactory.CSharp { @@ -410,7 +410,7 @@ namespace ICSharpCode.NRefactory.CSharp {
[Test]
public void OrderingWorks() {
var node = ParseUtilCSharp.ParseExpression<QueryExpression>("from i in arr1 orderby i.field1 select i");
var actual = new QueryExpressionExpander().ExpandQueryPattern(node);
var actual = new QueryExpressionExpander().ExpandQueryExpression(node);
AssertCorrect(actual.AstNode, "arr1.OrderBy(i => i.field1)");
dynamic astNode = actual.AstNode;
AssertLookupCorrect(actual.RangeVariables, new[] {
@ -427,7 +427,7 @@ namespace ICSharpCode.NRefactory.CSharp { @@ -427,7 +427,7 @@ namespace ICSharpCode.NRefactory.CSharp {
[Test]
public void OrderingWorksWhenThereIsATransparentIdentifier() {
var node = ParseUtilCSharp.ParseExpression<QueryExpression>("from i in arr1 let j = i + 1 orderby i + j select i");
var actual = new QueryExpressionExpander().ExpandQueryPattern(node);
var actual = new QueryExpressionExpander().ExpandQueryExpression(node);
AssertCorrect(actual.AstNode, "arr1.Select(i => new { i, j = i + 1 }).OrderBy(x0 => x0.i + x0.j).Select(x1 => x1.i)");
dynamic astNode = actual.AstNode;
AssertLookupCorrect(actual.RangeVariables, new[] {
@ -446,7 +446,7 @@ namespace ICSharpCode.NRefactory.CSharp { @@ -446,7 +446,7 @@ namespace ICSharpCode.NRefactory.CSharp {
[Test, Ignore("Parser bug")]
public void ThenByWorks() {
var node = ParseUtilCSharp.ParseExpression<QueryExpression>("from i in arr1 orderby i.field1, i.field2 select i");
var actual = new QueryExpressionExpander().ExpandQueryPattern(node);
var actual = new QueryExpressionExpander().ExpandQueryExpression(node);
Assert.Fail("TODO: Assertions must be fixed");
AssertCorrect(actual.AstNode, "arr1.OrderBy(i => i.field1).ThenBy(i => i.field2)");
dynamic astNode = actual.AstNode;
@ -463,7 +463,7 @@ namespace ICSharpCode.NRefactory.CSharp { @@ -463,7 +463,7 @@ namespace ICSharpCode.NRefactory.CSharp {
[Test, Ignore("Parser bug")]
public void OrderingDescendingWorks() {
var node = ParseUtilCSharp.ParseExpression<QueryExpression>("from i in arr1 orderby i.field1 descending, i.field2 descending select i");
var actual = new QueryExpressionExpander().ExpandQueryPattern(node);
var actual = new QueryExpressionExpander().ExpandQueryExpression(node);
Assert.Fail("TODO: Assertions must be fixed");
AssertCorrect(actual.AstNode, "arr1.OrderByDescending(i => i.field1).ThenByDescending(i => i.field2)");
dynamic astNode = actual.AstNode;
@ -480,7 +480,7 @@ namespace ICSharpCode.NRefactory.CSharp { @@ -480,7 +480,7 @@ namespace ICSharpCode.NRefactory.CSharp {
[Test]
public void QueryContinuation() {
var node = ParseUtilCSharp.ParseExpression<QueryExpression>("from i in arr1 from j in arr2 select i + j into a where a > 5 select a + 1");
var actual = new QueryExpressionExpander().ExpandQueryPattern(node);
var actual = new QueryExpressionExpander().ExpandQueryExpression(node);
AssertCorrect(actual.AstNode, "arr1.SelectMany(i => arr2, (i, j) => i + j).Where(a => a > 5).Select(a => a + 1)");
dynamic astNode = actual.AstNode;
AssertLookupCorrect(actual.RangeVariables, new[] {
@ -501,15 +501,22 @@ namespace ICSharpCode.NRefactory.CSharp { @@ -501,15 +501,22 @@ namespace ICSharpCode.NRefactory.CSharp {
[Test]
public void NestedQueries() {
var node = ParseUtilCSharp.ParseExpression<QueryExpression>("from i in arr1 from j in arr2 let l = new { i, j } group l by l.i into g select new { g.Key, a = from q in g select new { q.i, q.j } }");
var actual = new QueryExpressionExpander().ExpandQueryPattern(node);
var actual = new QueryExpressionExpander().ExpandQueryExpression(node);
AssertCorrect(actual.AstNode, "arr1.SelectMany(i => arr2, (i, j) => new { i, j }).Select(x0 => new { x0, l = new { x0.i, x0.j } }).GroupBy(x1 => x1.l.i, x2 => x2.l).Select(g => new { g.Key, a = g.Select(q => new { q.i, q.j }) })");
}
[Test]
public void NestedQueryUsingRangeVariableFromOuter() {
var node = ParseUtilCSharp.ParseExpression<QueryExpression>("from i in arr1 from j in arr2 let k = new[] { i, j } select (from l in k let m = l + 1 select l + m + i)");
var actual = new QueryExpressionExpander().ExpandQueryPattern(node);
var actual = new QueryExpressionExpander().ExpandQueryExpression(node);
AssertCorrect(actual.AstNode, "arr1.SelectMany(i => arr2, (i, j) => new { i, j }).Select(x0 => new { x0, k = new[] { x0.i, x0.j } }).Select(x1 => (x1.k.Select(l => new { l, m = l + 1 }).Select(x2 => x2.l + x2.m + x1.x0.i)))");
}
[Test]
public void RangeVariablesAreNotInScopeInJoinEquals() {
var node = ParseUtilCSharp.ParseExpression<QueryExpression>("from a in args let a2 = a select (from b in args let b2 = b join c in args on b[0] equals b + a into g select g)");
var actual = new QueryExpressionExpander().ExpandQueryExpression(node);
AssertCorrect(actual.AstNode, "args.Select(a => new { a, a2 = a }).Select(x0 => (args.Select(b => new { b, b2 = b }).GroupJoin(args, x1 => x1.b[0], c => b + x0.a, (x2, g) => g)))");
}
}
}

Loading…
Cancel
Save