From a45bdb51079a4ee609ec3c0678824c380ea3910f Mon Sep 17 00:00:00 2001 From: Smit Patel Date: Thu, 29 Aug 2019 10:40:48 -0700 Subject: [PATCH] Update query logging tests Filed #17498 to add logging Resolves #17245 --- .../Query/QueryLoggingSqlServerTest.cs | 113 ++++++------------ 1 file changed, 39 insertions(+), 74 deletions(-) diff --git a/test/EFCore.SqlServer.FunctionalTests/Query/QueryLoggingSqlServerTest.cs b/test/EFCore.SqlServer.FunctionalTests/Query/QueryLoggingSqlServerTest.cs index ba5545bffbd..81b755b7ea1 100644 --- a/test/EFCore.SqlServer.FunctionalTests/Query/QueryLoggingSqlServerTest.cs +++ b/test/EFCore.SqlServer.FunctionalTests/Query/QueryLoggingSqlServerTest.cs @@ -15,7 +15,6 @@ // ReSharper disable InconsistentNaming namespace Microsoft.EntityFrameworkCore.Query { - // Issue #16963 public class QueryLoggingSqlServerTest : IClassFixture { private static readonly string _eol = Environment.NewLine; @@ -65,93 +64,58 @@ var customers } } - //[ConditionalFact] - //public virtual void Query_with_ignored_include_should_log_warning() - //{ - // using (var context = CreateContext()) - // { - // var customers - // = context.Customers - // .Include(c => c.Orders) - // .Select(c => c.CustomerID) - // .ToList(); - - // Assert.NotNull(customers); - // Assert.Contains( - // CoreResources.LogIgnoredInclude(new TestLogger()).GenerateMessage("[c].Orders"), Fixture.TestSqlLoggerFactory.Log.Select(l => l.Message)); - // } - //} - - //[ConditionalFact] - //public virtual void Include_navigation() - //{ - // using (var context = CreateContext()) - // { - // var customers - // = context.Set() - // .Include(c => c.Orders) - // .ToList(); - - // Assert.NotNull(customers); - - // Assert.Equal( - // "Compiling query model: " + _eol + - // "'(from Customer c in DbSet" + _eol + - // @"select [c]).Include(""Orders"")'" - // , - // Fixture.TestSqlLoggerFactory.Log[0].Message); - // Assert.Equal( - // "Including navigation: '[c].Orders'" - // , - // Fixture.TestSqlLoggerFactory.Log[1].Message); - // Assert.StartsWith( - // "Optimized query model: " + _eol + - // "'from Customer c in DbSet" + _eol + - // @"order by EF.Property(?[c]?, ""CustomerID"") asc" + _eol + - // "select Customer _Include(" - // , - // Fixture.TestSqlLoggerFactory.Log[2].Message); - // } - //} - -#pragma warning disable CS0612 // Type or member is obsolete - [ConditionalFact(Skip = "Issue #17245")] - public virtual void Concat_Include_collection_ignored() + [ConditionalFact(Skip = "Issue#17498")] + public virtual void Query_with_ignored_include_should_log_warning() { using (var context = CreateContext()) { - var orders = context.Orders - .Where(o => o.OrderID < 10250) - .Concat(context.Orders.Where(o => o.CustomerID == "ALFKI")) - .Include(o => o.OrderDetails) - .ToList(); + var customers + = context.Customers + .Include(c => c.Orders) + .Select(c => c.CustomerID) + .ToList(); - Assert.NotNull(orders); + Assert.NotNull(customers); Assert.Contains( - CoreResources.LogIgnoredInclude(new TestLogger()).GenerateMessage("[o].OrderDetails"), - Fixture.TestSqlLoggerFactory.Log.Select(l => l.Message)); +#pragma warning disable CS0612 // Type or member is obsolete + CoreResources.LogIgnoredInclude(new TestLogger()).GenerateMessage("[c].Orders"), Fixture.TestSqlLoggerFactory.Log.Select(l => l.Message)); +#pragma warning restore CS0612 // Type or member is obsolete } } - [ConditionalFact(Skip = "Issue #17245")] - public virtual void Union_Include_collection_ignored() + [ConditionalFact(Skip = "Issue#17498")] + public virtual void Include_navigation() { using (var context = CreateContext()) { - var orders = context.Orders - .Where(o => o.OrderID < 10250) - .Union(context.Orders.Where(o => o.CustomerID == "ALFKI")) - .Include(o => o.OrderDetails) - .ToList(); + var customers + = context.Set() + .Include(c => c.Orders) + .ToList(); - Assert.NotNull(orders); - Assert.Contains( - CoreResources.LogIgnoredInclude(new TestLogger()).GenerateMessage("[o].OrderDetails"), - Fixture.TestSqlLoggerFactory.Log.Select(l => l.Message)); + Assert.NotNull(customers); + + Assert.Equal( + "Compiling query model: " + _eol + + "'(from Customer c in DbSet" + _eol + + @"select [c]).Include(""Orders"")'" + , + Fixture.TestSqlLoggerFactory.Log[0].Message); + Assert.Equal( + "Including navigation: '[c].Orders'" + , + Fixture.TestSqlLoggerFactory.Log[1].Message); + Assert.StartsWith( + "Optimized query model: " + _eol + + "'from Customer c in DbSet" + _eol + + @"order by EF.Property(?[c]?, ""CustomerID"") asc" + _eol + + "select Customer _Include(" + , + Fixture.TestSqlLoggerFactory.Log[2].Message); } } - [ConditionalFact(Skip = "Issue #17068")] + [ConditionalFact(Skip = "Issue #16752")] public virtual void GroupBy_Include_collection_ignored() { using (var context = CreateContext()) @@ -164,12 +128,13 @@ public virtual void GroupBy_Include_collection_ignored() Assert.NotNull(orders); Assert.Contains( +#pragma warning disable CS0612 // Type or member is obsolete CoreResources.LogIgnoredInclude(new TestLogger()).GenerateMessage( +#pragma warning restore CS0612 // Type or member is obsolete "{from Order o in [g] orderby [o].OrderID asc select [o] => FirstOrDefault()}.OrderDetails"), Fixture.TestSqlLoggerFactory.Log.Select(l => l.Message)); } } -#pragma warning restore CS0612 // Type or member is obsolete [ConditionalFact] public void SelectExpression_does_not_use_an_old_logger()