From 1e4d2e5f9949dccc2acfecdf47b8c4cd38e02727 Mon Sep 17 00:00:00 2001 From: AndriySvyryd Date: Mon, 12 Aug 2019 17:11:24 -0700 Subject: [PATCH] Don't run Select_nested_projection without MARS Fixes #17117 --- .../Query/SimpleQueryCosmosTest.Select.cs | 6 -- .../Query/SimpleQueryTestBase.Select.cs | 26 -------- .../Query/QueryBugsTest.cs | 61 +++++++++++++++++++ 3 files changed, 61 insertions(+), 32 deletions(-) diff --git a/test/EFCore.Cosmos.FunctionalTests/Query/SimpleQueryCosmosTest.Select.cs b/test/EFCore.Cosmos.FunctionalTests/Query/SimpleQueryCosmosTest.Select.cs index 95c78c858d9..926a4aac751 100644 --- a/test/EFCore.Cosmos.FunctionalTests/Query/SimpleQueryCosmosTest.Select.cs +++ b/test/EFCore.Cosmos.FunctionalTests/Query/SimpleQueryCosmosTest.Select.cs @@ -257,12 +257,6 @@ FROM root c WHERE ((c[""Discriminator""] = ""Customer"") AND (c[""City""] = ""London""))"); } - [ConditionalTheory(Skip = "Issue #16143")] - public override void Select_nested_projection() - { - base.Select_nested_projection(); - } - public override async Task Select_nested_collection(bool isAsync) { await base.Select_nested_collection(isAsync); diff --git a/test/EFCore.Specification.Tests/Query/SimpleQueryTestBase.Select.cs b/test/EFCore.Specification.Tests/Query/SimpleQueryTestBase.Select.cs index 1036067e8c0..d9cc42d083b 100644 --- a/test/EFCore.Specification.Tests/Query/SimpleQueryTestBase.Select.cs +++ b/test/EFCore.Specification.Tests/Query/SimpleQueryTestBase.Select.cs @@ -408,32 +408,6 @@ from c in cs select c.City); } - [ConditionalFact] - public virtual void Select_nested_projection() - { - using (var context = CreateContext()) - { - var customers = context.Customers - .Where(c => c.CustomerID.StartsWith("A")) - .Select(c => new - { - Customer = c, - CustomerAgain = Get(context, c.CustomerID) - }) - .ToList(); - - Assert.Equal(4, customers.Count); - - foreach (var customer in customers) - { - Assert.Same(customer.Customer, customer.CustomerAgain); - } - } - } - - private static Customer Get(NorthwindContext context, string id) - => context.Customers.Single(c => c.CustomerID == id); - [ConditionalTheory(Skip = "Issue#16314")] [MemberData(nameof(IsAsyncData))] public virtual Task Select_nested_collection(bool isAsync) diff --git a/test/EFCore.SqlServer.FunctionalTests/Query/QueryBugsTest.cs b/test/EFCore.SqlServer.FunctionalTests/Query/QueryBugsTest.cs index 31162d5251a..eba702cd03c 100644 --- a/test/EFCore.SqlServer.FunctionalTests/Query/QueryBugsTest.cs +++ b/test/EFCore.SqlServer.FunctionalTests/Query/QueryBugsTest.cs @@ -6071,6 +6071,67 @@ public class Repo15518 #endregion + #region Bug8864 + + [ConditionalFact] + public virtual void Select_nested_projection() + { + using (CreateDatabase8864()) + { + using (var context = new MyContext8864(_options)) + { + var customers = context.Customers + .Select(c => new + { + Customer = c, + CustomerAgain = Get(context, c.Id) + }) + .ToList(); + + Assert.Equal(2, customers.Count); + + foreach (var customer in customers) + { + Assert.Same(customer.Customer, customer.CustomerAgain); + } + } + } + } + + private static Customer8864 Get(MyContext8864 context, int id) + => context.Customers.Single(c => c.Id == id); + + private SqlServerTestStore CreateDatabase8864() + => CreateTestStore( + () => new MyContext8864(_options), + context => + { + context.AddRange( + new Customer8864 { Name = "Alan" }, + new Customer8864 { Name = "Elon" }); + + context.SaveChanges(); + + ClearLog(); + }); + + public class MyContext8864 : DbContext + { + public DbSet Customers { get; set; } + + public MyContext8864(DbContextOptions options) : base(options) + { + } + } + + public class Customer8864 + { + public int Id { get; set; } + public string Name { get; set; } + } + + #endregion + private DbContextOptions _options; private SqlServerTestStore CreateTestStore(