From b4bdc29861771206dbb4ad6f7fb5e90588ca1f5a Mon Sep 17 00:00:00 2001 From: AliReZa Sabouri Date: Mon, 2 Dec 2024 20:09:17 +0100 Subject: [PATCH] test: add Mapper DisableCollectionNullChecks --- test/Gridify.Tests/GridifyExtensionsShould.cs | 19 ++++++++++++++++++- 1 file changed, 18 insertions(+), 1 deletion(-) diff --git a/test/Gridify.Tests/GridifyExtensionsShould.cs b/test/Gridify.Tests/GridifyExtensionsShould.cs index dff64141..5b61108e 100644 --- a/test/Gridify.Tests/GridifyExtensionsShould.cs +++ b/test/Gridify.Tests/GridifyExtensionsShould.cs @@ -2,6 +2,7 @@ using Gridify.Syntax; using System; using System.Collections.Generic; +using System.Diagnostics.CodeAnalysis; using System.Linq; using System.Linq.Expressions; using Xunit; @@ -135,7 +136,7 @@ public void ApplyFiltering_NullHandlingUsingCustomConvertor() Assert.Equal(expected, actual); Assert.True(actual.Any()); } - + [Fact] // issue #220 public void ApplyFiltering_CustomConvertor_ReturningNull_ShouldWork() { @@ -695,6 +696,20 @@ public void ApplyFiltering_UnmappedFields_ShouldSkipWhenIgnored() Assert.True(actual.Any()); } + [Fact] // issue #238 + public void ApplyFiltering_MapperDisableCollectionNullChecks_ShouldPreventAddingNullChecks() + { + var gm = new GridifyMapper(configuration => configuration.DisableCollectionNullChecks = true) + .AddMap("name", q => q.Children.Select(w => w.Name)); + +#pragma warning disable CS8602 // Dereference of a possibly null reference. + var expected = _fakeRepository.AsQueryable().Where(q => q.Children.Any(w => w.Name.Contains("a"))).ToString(); +#pragma warning restore CS8602 // Dereference of a possibly null reference. + var actual = _fakeRepository.AsQueryable().ApplyFiltering("name=*a", gm).ToString(); + + Assert.Equal(expected, actual); + } + #endregion @@ -723,6 +738,8 @@ private class TestOperator : UpperCaseEqual }; [Fact] + [SuppressMessage("Assertions", "xUnit2031:Do not use Where clause with Assert.Single")] + [SuppressMessage("Assertions", "xUnit2029:Do not use Assert.Empty to check if a value does not exist in a collection")] public void CustomOperator_GenericRegisterAndRemove_ShouldNotThrowAnyException() { GridifyGlobalConfiguration.CustomOperators.Register();