diff --git a/Directory.Build.props b/Directory.Build.props
index a1a2c26d3..ee9eb6a7b 100644
--- a/Directory.Build.props
+++ b/Directory.Build.props
@@ -3,6 +3,7 @@
10.0.0
net10.0
latest
+ enable
true
latest
NU5105
diff --git a/src/Directory.Build.props b/src/Directory.Build.props
index 609d0a4e7..b5e6b77b5 100644
--- a/src/Directory.Build.props
+++ b/src/Directory.Build.props
@@ -5,7 +5,6 @@
true
snupkg
true
- enable
nullablePublicOnly
diff --git a/test/EFCore.PG.FunctionalTests/BadDataJsonDeserializationNpgsqlTest.cs b/test/EFCore.PG.FunctionalTests/BadDataJsonDeserializationNpgsqlTest.cs
index dcf301eba..29e0cfa28 100644
--- a/test/EFCore.PG.FunctionalTests/BadDataJsonDeserializationNpgsqlTest.cs
+++ b/test/EFCore.PG.FunctionalTests/BadDataJsonDeserializationNpgsqlTest.cs
@@ -1,5 +1,3 @@
-#nullable enable
-
namespace Npgsql.EntityFrameworkCore.PostgreSQL;
public class BadDataJsonDeserializationSqlServerTest : BadDataJsonDeserializationTestBase
diff --git a/test/EFCore.PG.FunctionalTests/BatchingTest.cs b/test/EFCore.PG.FunctionalTests/BatchingTest.cs
index f7c87c74d..5f3fe5761 100644
--- a/test/EFCore.PG.FunctionalTests/BatchingTest.cs
+++ b/test/EFCore.PG.FunctionalTests/BatchingTest.cs
@@ -7,6 +7,8 @@
// ReSharper disable InconsistentNaming
namespace Npgsql.EntityFrameworkCore.PostgreSQL;
+#nullable disable
+
public class BatchingTest(BatchingTest.BatchingTestFixture fixture) : IClassFixture
{
protected BatchingTestFixture Fixture { get; } = fixture;
diff --git a/test/EFCore.PG.FunctionalTests/BuiltInDataTypesNpgsqlTest.cs b/test/EFCore.PG.FunctionalTests/BuiltInDataTypesNpgsqlTest.cs
index 99c1a5996..59433e393 100644
--- a/test/EFCore.PG.FunctionalTests/BuiltInDataTypesNpgsqlTest.cs
+++ b/test/EFCore.PG.FunctionalTests/BuiltInDataTypesNpgsqlTest.cs
@@ -5,6 +5,8 @@
namespace Npgsql.EntityFrameworkCore.PostgreSQL;
+#nullable disable
+
public class BuiltInDataTypesNpgsqlTest : BuiltInDataTypesTestBase
{
// ReSharper disable once UnusedParameter.Local
diff --git a/test/EFCore.PG.FunctionalTests/BulkUpdates/NonSharedModelBulkUpdatesNpgsqlTest.cs b/test/EFCore.PG.FunctionalTests/BulkUpdates/NonSharedModelBulkUpdatesNpgsqlTest.cs
index 6672c16b7..55b9460fe 100644
--- a/test/EFCore.PG.FunctionalTests/BulkUpdates/NonSharedModelBulkUpdatesNpgsqlTest.cs
+++ b/test/EFCore.PG.FunctionalTests/BulkUpdates/NonSharedModelBulkUpdatesNpgsqlTest.cs
@@ -236,7 +236,7 @@ protected class Context3001(DbContextOptions options) : DbContext(options)
protected class EntityWithPrimitiveCollection
{
public int Id { get; set; }
- public List Tags { get; set; }
+ public List Tags { get; set; } = null!;
}
public override async Task Delete_with_view_mapping(bool async)
diff --git a/test/EFCore.PG.FunctionalTests/ComputedColumnTest.cs b/test/EFCore.PG.FunctionalTests/ComputedColumnTest.cs
index 5c3c86cab..49f767528 100644
--- a/test/EFCore.PG.FunctionalTests/ComputedColumnTest.cs
+++ b/test/EFCore.PG.FunctionalTests/ComputedColumnTest.cs
@@ -134,7 +134,7 @@ public void Can_use_computed_columns_with_nullable_enum()
Assert.Equal(FlagEnum.AValue | FlagEnum.BValue, entity.CalculatedFlagEnum);
}
- protected NpgsqlTestStore TestStore { get; private set; }
+ protected NpgsqlTestStore TestStore { get; private set; } = null!;
public async Task InitializeAsync()
=> TestStore = await NpgsqlTestStore.CreateInitializedAsync("ComputedColumnTest");
diff --git a/test/EFCore.PG.FunctionalTests/ConferencePlannerNpgsqlTest.cs b/test/EFCore.PG.FunctionalTests/ConferencePlannerNpgsqlTest.cs
index fbfe6f2c2..eed20e42f 100644
--- a/test/EFCore.PG.FunctionalTests/ConferencePlannerNpgsqlTest.cs
+++ b/test/EFCore.PG.FunctionalTests/ConferencePlannerNpgsqlTest.cs
@@ -4,6 +4,8 @@
namespace Npgsql.EntityFrameworkCore.PostgreSQL;
+#nullable disable
+
public class ConferencePlannerNpgsqlTest(ConferencePlannerNpgsqlTest.ConferencePlannerNpgsqlFixture fixture)
: ConferencePlannerTestBase(fixture)
{
diff --git a/test/EFCore.PG.FunctionalTests/ConnectionInterceptionNpgsqlTest.cs b/test/EFCore.PG.FunctionalTests/ConnectionInterceptionNpgsqlTest.cs
index 2d8f44e13..c111fc4e1 100644
--- a/test/EFCore.PG.FunctionalTests/ConnectionInterceptionNpgsqlTest.cs
+++ b/test/EFCore.PG.FunctionalTests/ConnectionInterceptionNpgsqlTest.cs
@@ -1,5 +1,6 @@
using System.Data;
using System.Data.Common;
+using System.Diagnostics.CodeAnalysis;
using Npgsql.EntityFrameworkCore.PostgreSQL.TestUtilities;
namespace Npgsql.EntityFrameworkCore.PostgreSQL;
@@ -45,6 +46,7 @@ protected override BadUniverseContext CreateBadUniverse(DbContextOptionsBuilder
public class FakeDbConnection : DbConnection
{
+ [AllowNull]
public override string ConnectionString { get; set; }
public override string Database
diff --git a/test/EFCore.PG.FunctionalTests/ConnectionSpecificationTest.cs b/test/EFCore.PG.FunctionalTests/ConnectionSpecificationTest.cs
index 2cac8e343..f75b6186d 100644
--- a/test/EFCore.PG.FunctionalTests/ConnectionSpecificationTest.cs
+++ b/test/EFCore.PG.FunctionalTests/ConnectionSpecificationTest.cs
@@ -4,6 +4,8 @@
// ReSharper disable StringLiteralTypo
namespace Npgsql.EntityFrameworkCore.PostgreSQL;
+#nullable disable
+
public class ConnectionSpecificationTest
{
[Fact]
diff --git a/test/EFCore.PG.FunctionalTests/DefaultValuesTest.cs b/test/EFCore.PG.FunctionalTests/DefaultValuesTest.cs
index 611655a01..6a7977d94 100644
--- a/test/EFCore.PG.FunctionalTests/DefaultValuesTest.cs
+++ b/test/EFCore.PG.FunctionalTests/DefaultValuesTest.cs
@@ -69,7 +69,7 @@ private class KettleChips
{
// ReSharper disable once UnusedMember.Local
public int Id { get; set; }
- public string Name { get; set; }
+ public string Name { get; set; } = null!;
public DateTime BestBuyDate { get; set; }
}
}
diff --git a/test/EFCore.PG.FunctionalTests/ExecutionStrategyTest.cs b/test/EFCore.PG.FunctionalTests/ExecutionStrategyTest.cs
index f488081c6..542f95432 100644
--- a/test/EFCore.PG.FunctionalTests/ExecutionStrategyTest.cs
+++ b/test/EFCore.PG.FunctionalTests/ExecutionStrategyTest.cs
@@ -7,6 +7,8 @@
// ReSharper disable AccessToDisposedClosure
namespace Npgsql.EntityFrameworkCore.PostgreSQL;
+#nullable disable
+
public class ExecutionStrategyTest : IClassFixture
{
public ExecutionStrategyTest(ExecutionStrategyFixture fixture)
diff --git a/test/EFCore.PG.FunctionalTests/ExistingConnectionTest.cs b/test/EFCore.PG.FunctionalTests/ExistingConnectionTest.cs
index abbe8f3f5..f7b2fcffc 100644
--- a/test/EFCore.PG.FunctionalTests/ExistingConnectionTest.cs
+++ b/test/EFCore.PG.FunctionalTests/ExistingConnectionTest.cs
@@ -93,12 +93,12 @@ protected override void OnModelCreating(ModelBuilder modelBuilder)
private class Customer
{
// ReSharper disable once UnusedAutoPropertyAccessor.Local
- public string CustomerId { get; set; }
+ public string CustomerId { get; set; } = null!;
// ReSharper disable once UnusedMember.Local
- public string CompanyName { get; set; }
+ public string CompanyName { get; set; } = null!;
// ReSharper disable once UnusedMember.Local
- public string Fax { get; set; }
+ public string Fax { get; set; } = null!;
}
}
diff --git a/test/EFCore.PG.FunctionalTests/F1NpgsqlFixture.cs b/test/EFCore.PG.FunctionalTests/F1NpgsqlFixture.cs
index 91be0a0e5..3281de74b 100644
--- a/test/EFCore.PG.FunctionalTests/F1NpgsqlFixture.cs
+++ b/test/EFCore.PG.FunctionalTests/F1NpgsqlFixture.cs
@@ -34,15 +34,15 @@ protected override void BuildModelExternal(ModelBuilder modelBuilder)
base.BuildModelExternal(modelBuilder);
// TODO: This is a hack to work around, remove in 8.0 after https://github.com/dotnet/efcore/pull/29401
- modelBuilder.Entity().Property("Version").HasConversion((ValueConverter)null);
- modelBuilder.Entity().Property("Version").HasConversion((ValueConverter)null);
- modelBuilder.Entity().Property("Version").HasConversion((ValueConverter)null);
- modelBuilder.Entity().Property("Version").HasConversion((ValueConverter)null);
+ modelBuilder.Entity().Property("Version").HasConversion((ValueConverter?)null);
+ modelBuilder.Entity().Property("Version").HasConversion((ValueConverter?)null);
+ modelBuilder.Entity().Property("Version").HasConversion((ValueConverter?)null);
+ modelBuilder.Entity().Property("Version").HasConversion((ValueConverter?)null);
modelBuilder.Entity()
.OwnsOne(
s => s.Details, eb =>
{
- eb.Property("Version").IsRowVersion().HasConversion((ValueConverter)null);
+ eb.Property("Version").IsRowVersion().HasConversion((ValueConverter?)null);
});
}
}
diff --git a/test/EFCore.PG.FunctionalTests/JsonTypesNpgsqlTest.cs b/test/EFCore.PG.FunctionalTests/JsonTypesNpgsqlTest.cs
index 1f15efa71..f3b5b20d2 100644
--- a/test/EFCore.PG.FunctionalTests/JsonTypesNpgsqlTest.cs
+++ b/test/EFCore.PG.FunctionalTests/JsonTypesNpgsqlTest.cs
@@ -1,5 +1,3 @@
-#nullable enable
-
using System.Collections;
using System.Globalization;
using System.Numerics;
diff --git a/test/EFCore.PG.FunctionalTests/LazyLoadProxyNpgsqlTest.cs b/test/EFCore.PG.FunctionalTests/LazyLoadProxyNpgsqlTest.cs
index 77f463f4f..b299a9f9b 100644
--- a/test/EFCore.PG.FunctionalTests/LazyLoadProxyNpgsqlTest.cs
+++ b/test/EFCore.PG.FunctionalTests/LazyLoadProxyNpgsqlTest.cs
@@ -25,7 +25,7 @@ protected override void RecordLog()
=> Sql = Fixture.TestSqlLoggerFactory.Sql;
// ReSharper disable once UnusedAutoPropertyAccessor.Local
- private string Sql { get; set; }
+ private string Sql { get; set; } = null!;
#region Expected JSON override
diff --git a/test/EFCore.PG.FunctionalTests/LoadNpgsqlTest.cs b/test/EFCore.PG.FunctionalTests/LoadNpgsqlTest.cs
index 3a982ba6c..1b11afc96 100644
--- a/test/EFCore.PG.FunctionalTests/LoadNpgsqlTest.cs
+++ b/test/EFCore.PG.FunctionalTests/LoadNpgsqlTest.cs
@@ -18,7 +18,7 @@ protected override void RecordLog()
=> Sql = Fixture.TestSqlLoggerFactory.Sql;
// ReSharper disable once UnusedAutoPropertyAccessor.Local
- private string Sql { get; set; }
+ private string Sql { get; set; } = null!;
public class LoadNpgsqlFixture : LoadFixtureBase
{
diff --git a/test/EFCore.PG.FunctionalTests/LoggingNpgsqlTest.cs b/test/EFCore.PG.FunctionalTests/LoggingNpgsqlTest.cs
index a495a96cb..ad77a5eb3 100644
--- a/test/EFCore.PG.FunctionalTests/LoggingNpgsqlTest.cs
+++ b/test/EFCore.PG.FunctionalTests/LoggingNpgsqlTest.cs
@@ -72,5 +72,5 @@ protected override string ProviderName
protected override string ProviderVersion
=> typeof(NpgsqlOptionsExtension).Assembly
- .GetCustomAttribute()?.InformationalVersion;
+ .GetCustomAttribute()?.InformationalVersion!;
}
diff --git a/test/EFCore.PG.FunctionalTests/MaterializationInterceptionNpgsqlTest.cs b/test/EFCore.PG.FunctionalTests/MaterializationInterceptionNpgsqlTest.cs
index 1e44c27db..503a23f5d 100644
--- a/test/EFCore.PG.FunctionalTests/MaterializationInterceptionNpgsqlTest.cs
+++ b/test/EFCore.PG.FunctionalTests/MaterializationInterceptionNpgsqlTest.cs
@@ -1,5 +1,3 @@
-#nullable enable
-
using Npgsql.EntityFrameworkCore.PostgreSQL.TestUtilities;
namespace Npgsql.EntityFrameworkCore.PostgreSQL;
diff --git a/test/EFCore.PG.FunctionalTests/Migrations/MigrationsInfrastructureNpgsqlTest.cs b/test/EFCore.PG.FunctionalTests/Migrations/MigrationsInfrastructureNpgsqlTest.cs
index 542d3ddda..1675c11db 100644
--- a/test/EFCore.PG.FunctionalTests/Migrations/MigrationsInfrastructureNpgsqlTest.cs
+++ b/test/EFCore.PG.FunctionalTests/Migrations/MigrationsInfrastructureNpgsqlTest.cs
@@ -2,6 +2,8 @@
using Npgsql.EntityFrameworkCore.PostgreSQL.Storage.Internal;
using Npgsql.EntityFrameworkCore.PostgreSQL.TestUtilities;
+#nullable disable
+
namespace Npgsql.EntityFrameworkCore.PostgreSQL.Migrations
{
public class MigrationsInfrastructureNpgsqlTest(MigrationsInfrastructureNpgsqlTest.MigrationsInfrastructureNpgsqlFixture fixture)
diff --git a/test/EFCore.PG.FunctionalTests/Migrations/MigrationsNpgsqlTest.cs b/test/EFCore.PG.FunctionalTests/Migrations/MigrationsNpgsqlTest.cs
index 82918f6b8..f92cb4799 100644
--- a/test/EFCore.PG.FunctionalTests/Migrations/MigrationsNpgsqlTest.cs
+++ b/test/EFCore.PG.FunctionalTests/Migrations/MigrationsNpgsqlTest.cs
@@ -1,6 +1,4 @@
-#nullable enable
-
-using Npgsql.EntityFrameworkCore.PostgreSQL.Infrastructure;
+using Npgsql.EntityFrameworkCore.PostgreSQL.Infrastructure;
using Npgsql.EntityFrameworkCore.PostgreSQL.Metadata;
using Npgsql.EntityFrameworkCore.PostgreSQL.Metadata.Internal;
using Npgsql.EntityFrameworkCore.PostgreSQL.Scaffolding.Internal;
diff --git a/test/EFCore.PG.FunctionalTests/Migrations/NpgsqlMigrationsSqlGeneratorTest.cs b/test/EFCore.PG.FunctionalTests/Migrations/NpgsqlMigrationsSqlGeneratorTest.cs
index 0b3dc8292..a5881dec1 100644
--- a/test/EFCore.PG.FunctionalTests/Migrations/NpgsqlMigrationsSqlGeneratorTest.cs
+++ b/test/EFCore.PG.FunctionalTests/Migrations/NpgsqlMigrationsSqlGeneratorTest.cs
@@ -615,7 +615,7 @@ public override void InsertDataOperation_throws_for_unsupported_column_types()
Schema = "dbo",
Columns = ["First Name"],
ColumnTypes = ["foo"],
- Values = new object[,] { { null } }
+ Values = new object?[,] { { null } }
})).Message);
#pragma warning restore 618
diff --git a/test/EFCore.PG.FunctionalTests/ModelBuilding/NpgsqlModelBuilderGenericTest.cs b/test/EFCore.PG.FunctionalTests/ModelBuilding/NpgsqlModelBuilderGenericTest.cs
index 9478c332d..588c94336 100644
--- a/test/EFCore.PG.FunctionalTests/ModelBuilding/NpgsqlModelBuilderGenericTest.cs
+++ b/test/EFCore.PG.FunctionalTests/ModelBuilding/NpgsqlModelBuilderGenericTest.cs
@@ -2,8 +2,6 @@
namespace Npgsql.EntityFrameworkCore.PostgreSQL.ModelBuilding;
-#nullable enable
-
public class NpgsqlModelBuilderGenericTest : NpgsqlModelBuilderTestBase
{
public class NpgsqlGenericNonRelationship(NpgsqlModelBuilderFixture fixture) : NpgsqlNonRelationship(fixture)
diff --git a/test/EFCore.PG.FunctionalTests/ModelBuilding/NpgsqlModelBuilderTestBase.cs b/test/EFCore.PG.FunctionalTests/ModelBuilding/NpgsqlModelBuilderTestBase.cs
index afce39d7a..59ba51863 100644
--- a/test/EFCore.PG.FunctionalTests/ModelBuilding/NpgsqlModelBuilderTestBase.cs
+++ b/test/EFCore.PG.FunctionalTests/ModelBuilding/NpgsqlModelBuilderTestBase.cs
@@ -1,5 +1,3 @@
-#nullable enable
-
using Microsoft.EntityFrameworkCore.ModelBuilding;
using Npgsql.EntityFrameworkCore.PostgreSQL.TestUtilities;
diff --git a/test/EFCore.PG.FunctionalTests/NpgsqlApiConsistencyTest.cs b/test/EFCore.PG.FunctionalTests/NpgsqlApiConsistencyTest.cs
index 5b331b827..bb0b363e2 100644
--- a/test/EFCore.PG.FunctionalTests/NpgsqlApiConsistencyTest.cs
+++ b/test/EFCore.PG.FunctionalTests/NpgsqlApiConsistencyTest.cs
@@ -3,6 +3,8 @@
namespace Npgsql.EntityFrameworkCore.PostgreSQL;
+#nullable disable
+
public class NpgsqlApiConsistencyTest(NpgsqlApiConsistencyTest.NpgsqlApiConsistencyFixture fixture)
: ApiConsistencyTestBase(fixture)
{
diff --git a/test/EFCore.PG.FunctionalTests/NpgsqlDatabaseCreatorTest.cs b/test/EFCore.PG.FunctionalTests/NpgsqlDatabaseCreatorTest.cs
index 9954a7b15..f3fcb04c3 100644
--- a/test/EFCore.PG.FunctionalTests/NpgsqlDatabaseCreatorTest.cs
+++ b/test/EFCore.PG.FunctionalTests/NpgsqlDatabaseCreatorTest.cs
@@ -7,6 +7,8 @@
namespace Npgsql.EntityFrameworkCore.PostgreSQL;
+#nullable disable
+
public class NpgsqlDatabaseCreatorExistsTest : NpgsqlDatabaseCreatorTest
{
[ConditionalTheory]
diff --git a/test/EFCore.PG.FunctionalTests/NpgsqlValueGenerationScenariosTest.cs b/test/EFCore.PG.FunctionalTests/NpgsqlValueGenerationScenariosTest.cs
index bf6b1ca0d..276896683 100644
--- a/test/EFCore.PG.FunctionalTests/NpgsqlValueGenerationScenariosTest.cs
+++ b/test/EFCore.PG.FunctionalTests/NpgsqlValueGenerationScenariosTest.cs
@@ -3,6 +3,8 @@
namespace Npgsql.EntityFrameworkCore.PostgreSQL;
+#nullable disable
+
public class NpgsqlValueGenerationScenariosTest
{
private static readonly string DatabaseName = "NpgsqlValueGenerationScenariosTest";
diff --git a/test/EFCore.PG.FunctionalTests/OptimisticConcurrencyNpgsqlTest.cs b/test/EFCore.PG.FunctionalTests/OptimisticConcurrencyNpgsqlTest.cs
index e68095f3c..4162f307d 100644
--- a/test/EFCore.PG.FunctionalTests/OptimisticConcurrencyNpgsqlTest.cs
+++ b/test/EFCore.PG.FunctionalTests/OptimisticConcurrencyNpgsqlTest.cs
@@ -2,6 +2,8 @@
namespace Npgsql.EntityFrameworkCore.PostgreSQL;
+#nullable disable
+
public class OptimisticConcurrencyBytesNpgsqlTest(F1BytesNpgsqlFixture fixture)
: OptimisticConcurrencyNpgsqlTestBase(fixture);
diff --git a/test/EFCore.PG.FunctionalTests/Query/AdHocJsonQueryNpgsqlTest.cs b/test/EFCore.PG.FunctionalTests/Query/AdHocJsonQueryNpgsqlTest.cs
index 9dd0570f6..2893cc60a 100644
--- a/test/EFCore.PG.FunctionalTests/Query/AdHocJsonQueryNpgsqlTest.cs
+++ b/test/EFCore.PG.FunctionalTests/Query/AdHocJsonQueryNpgsqlTest.cs
@@ -2,6 +2,8 @@
namespace Npgsql.EntityFrameworkCore.PostgreSQL.Query;
+#nullable disable
+
public class AdHocJsonQueryNpgsqlTest : AdHocJsonQueryTestBase
{
protected override ITestStoreFactory TestStoreFactory
diff --git a/test/EFCore.PG.FunctionalTests/Query/AdHocQuerySplittingQueryNpgsqlTest.cs b/test/EFCore.PG.FunctionalTests/Query/AdHocQuerySplittingQueryNpgsqlTest.cs
index 927fe2ff8..d5c4a9e25 100644
--- a/test/EFCore.PG.FunctionalTests/Query/AdHocQuerySplittingQueryNpgsqlTest.cs
+++ b/test/EFCore.PG.FunctionalTests/Query/AdHocQuerySplittingQueryNpgsqlTest.cs
@@ -4,6 +4,8 @@
namespace Npgsql.EntityFrameworkCore.PostgreSQL.Query;
+#nullable disable
+
public class AdHocQuerySplittingQueryNpgsqlTest : AdHocQuerySplittingQueryTestBase
{
protected override DbContextOptionsBuilder SetQuerySplittingBehavior(
diff --git a/test/EFCore.PG.FunctionalTests/Query/ArrayArrayQueryTest.cs b/test/EFCore.PG.FunctionalTests/Query/ArrayArrayQueryTest.cs
index d0226d174..e6af296bf 100644
--- a/test/EFCore.PG.FunctionalTests/Query/ArrayArrayQueryTest.cs
+++ b/test/EFCore.PG.FunctionalTests/Query/ArrayArrayQueryTest.cs
@@ -235,7 +235,7 @@ public override void Array_column_Contains_null_parameter_does_not_work()
{
using var ctx = CreateContext();
- string p = null;
+ string? p = null;
// We incorrectly miss arrays containing non-constant nulls, because detecting those
// would prevent index use.
@@ -642,7 +642,7 @@ await AssertQuery(
ss => ss.Set()
.Where(e => new[] { "a%", "b%", "c%" }.Any(p => EF.Functions.Like(e.NullableText, p))),
ss => ss.Set()
- .Where(e => new[] { "a", "b", "c" }.Any(p => e.NullableText.StartsWith(p, StringComparison.Ordinal))));
+ .Where(e => new[] { "a", "b", "c" }.Any(p => e.NullableText!.StartsWith(p, StringComparison.Ordinal))));
AssertSql(
"""
@@ -657,9 +657,9 @@ public override async Task Any_ilike(bool async)
await AssertQuery(
async,
ss => ss.Set()
- .Where(e => new[] { "a%", "b%", "c%" }.Any(p => EF.Functions.ILike(e.NullableText, p))),
+ .Where(e => new[] { "a%", "b%", "c%" }.Any(p => EF.Functions.ILike(e.NullableText!, p))),
ss => ss.Set()
- .Where(e => new[] { "a", "b", "c" }.Any(p => e.NullableText.StartsWith(p, StringComparison.OrdinalIgnoreCase))));
+ .Where(e => new[] { "a", "b", "c" }.Any(p => e.NullableText!.StartsWith(p, StringComparison.OrdinalIgnoreCase))));
AssertSql(
"""
@@ -681,7 +681,7 @@ await AssertQuery(
ss => ss.Set()
.Where(e => patternsActual.Any(p => EF.Functions.Like(e.NullableText, p))),
ss => ss.Set()
- .Where(e => patternsExpected.Any(p => e.NullableText.StartsWith(p, StringComparison.Ordinal))));
+ .Where(e => patternsExpected.Any(p => e.NullableText!.StartsWith(p, StringComparison.Ordinal))));
AssertSql(
"""
@@ -700,7 +700,7 @@ await AssertQuery(
ss => ss.Set()
.Where(e => new[] { "b%", "ba%" }.All(p => EF.Functions.Like(e.NullableText, p))),
ss => ss.Set()
- .Where(e => new[] { "b", "ba" }.All(p => e.NullableText.StartsWith(p, StringComparison.Ordinal))));
+ .Where(e => new[] { "b", "ba" }.All(p => e.NullableText!.StartsWith(p, StringComparison.Ordinal))));
AssertSql(
"""
@@ -715,9 +715,9 @@ public override async Task All_ilike(bool async)
await AssertQuery(
async,
ss => ss.Set()
- .Where(e => new[] { "B%", "ba%" }.All(p => EF.Functions.ILike(e.NullableText, p))),
+ .Where(e => new[] { "B%", "ba%" }.All(p => EF.Functions.ILike(e.NullableText!, p))),
ss => ss.Set()
- .Where(e => new[] { "B", "ba" }.All(p => e.NullableText.StartsWith(p, StringComparison.OrdinalIgnoreCase))));
+ .Where(e => new[] { "B", "ba" }.All(p => e.NullableText!.StartsWith(p, StringComparison.OrdinalIgnoreCase))));
AssertSql(
"""
diff --git a/test/EFCore.PG.FunctionalTests/Query/ArrayListQueryTest.cs b/test/EFCore.PG.FunctionalTests/Query/ArrayListQueryTest.cs
index 896060c8f..8cc4c46f7 100644
--- a/test/EFCore.PG.FunctionalTests/Query/ArrayListQueryTest.cs
+++ b/test/EFCore.PG.FunctionalTests/Query/ArrayListQueryTest.cs
@@ -224,13 +224,13 @@ public override void Array_column_Contains_null_parameter_does_not_work()
{
using var ctx = CreateContext();
- string p = null;
+ string? p = null;
// We incorrectly miss arrays containing non-constant nulls, because detecting those
// would prevent index use.
Assert.Equal(
0,
- ctx.SomeEntities.Count(e => e.StringList.Contains(p)));
+ ctx.SomeEntities.Count(e => e.StringList.Contains(p!)));
AssertSql(
"""
@@ -272,7 +272,7 @@ public override async Task Array_param_Contains_nullable_column(bool async)
await AssertQuery(
async,
- ss => ss.Set().Where(e => array.Contains(e.NullableText)));
+ ss => ss.Set().Where(e => array.Contains(e.NullableText!)));
AssertSql(
"""
@@ -306,7 +306,7 @@ public override void Array_param_with_null_Contains_non_nullable_not_found()
{
using var ctx = CreateContext();
- var array = new List
+ var array = new List
{
"unknown1",
"unknown2",
@@ -329,7 +329,7 @@ public override void Array_param_with_null_Contains_non_nullable_not_found_negat
{
using var ctx = CreateContext();
- var array = new List
+ var array = new List
{
"unknown1",
"unknown2",
@@ -352,7 +352,7 @@ public override void Array_param_with_null_Contains_nullable_not_found()
{
using var ctx = CreateContext();
- var array = new List
+ var array = new List
{
"unknown1",
"unknown2",
@@ -375,14 +375,14 @@ public override void Array_param_with_null_Contains_nullable_not_found_negated()
{
using var ctx = CreateContext();
- var array = new List
+ var array = new List
{
"unknown1",
"unknown2",
null
};
- Assert.Equal(2, ctx.SomeEntities.Count(e => !array.Contains(e.NullableText)));
+ Assert.Equal(2, ctx.SomeEntities.Count(e => !array.Contains(e.NullableText!)));
AssertSql(
"""
@@ -650,7 +650,7 @@ await AssertQuery(
ss => ss.Set()
.Where(e => new[] { "a%", "b%", "c%" }.Any(p => EF.Functions.Like(e.NullableText, p))),
ss => ss.Set()
- .Where(e => new[] { "a", "b", "c" }.Any(p => e.NullableText.StartsWith(p, StringComparison.Ordinal))));
+ .Where(e => new[] { "a", "b", "c" }.Any(p => e.NullableText!.StartsWith(p, StringComparison.Ordinal))));
AssertSql(
"""
@@ -665,9 +665,9 @@ public override async Task Any_ilike(bool async)
await AssertQuery(
async,
ss => ss.Set()
- .Where(e => new[] { "a%", "b%", "c%" }.Any(p => EF.Functions.ILike(e.NullableText, p))),
+ .Where(e => new[] { "a%", "b%", "c%" }.Any(p => EF.Functions.ILike(e.NullableText!, p))),
ss => ss.Set()
- .Where(e => new[] { "a", "b", "c" }.Any(p => e.NullableText.StartsWith(p, StringComparison.OrdinalIgnoreCase))));
+ .Where(e => new[] { "a", "b", "c" }.Any(p => e.NullableText!.StartsWith(p, StringComparison.OrdinalIgnoreCase))));
AssertSql(
"""
@@ -699,7 +699,7 @@ await AssertQuery(
ss => ss.Set()
.Where(e => patternsActual.Any(p => EF.Functions.Like(e.NullableText, p))),
ss => ss.Set()
- .Where(e => patternsExpected.Any(p => e.NullableText.StartsWith(p, StringComparison.Ordinal))));
+ .Where(e => patternsExpected.Any(p => e.NullableText!.StartsWith(p, StringComparison.Ordinal))));
AssertSql(
"""
@@ -718,7 +718,7 @@ await AssertQuery(
ss => ss.Set()
.Where(e => new List { "b%", "ba%" }.All(p => EF.Functions.Like(e.NullableText, p))),
ss => ss.Set()
- .Where(e => new List { "b", "ba" }.All(p => e.NullableText.StartsWith(p, StringComparison.Ordinal))));
+ .Where(e => new List { "b", "ba" }.All(p => e.NullableText!.StartsWith(p, StringComparison.Ordinal))));
AssertSql(
"""
@@ -733,9 +733,9 @@ public override async Task All_ilike(bool async)
await AssertQuery(
async,
ss => ss.Set()
- .Where(e => new List { "B%", "ba%" }.All(p => EF.Functions.ILike(e.NullableText, p))),
+ .Where(e => new List { "B%", "ba%" }.All(p => EF.Functions.ILike(e.NullableText!, p))),
ss => ss.Set()
- .Where(e => new List { "B", "ba" }.All(p => e.NullableText.StartsWith(p, StringComparison.OrdinalIgnoreCase))));
+ .Where(e => new List { "B", "ba" }.All(p => e.NullableText!.StartsWith(p, StringComparison.OrdinalIgnoreCase))));
AssertSql(
"""
@@ -931,34 +931,34 @@ protected override Expression RewriteServerQueryExpression(Expression serverQuer
private class ArrayToListReplacingExpressionVisitor : ExpressionVisitor
{
private static readonly PropertyInfo IntArray
- = typeof(ArrayEntity).GetProperty(nameof(ArrayEntity.IntArray));
+ = typeof(ArrayEntity).GetProperty(nameof(ArrayEntity.IntArray))!;
private static readonly PropertyInfo NullableIntArray
- = typeof(ArrayEntity).GetProperty(nameof(ArrayEntity.NullableIntArray));
+ = typeof(ArrayEntity).GetProperty(nameof(ArrayEntity.NullableIntArray))!;
private static readonly PropertyInfo IntList
- = typeof(ArrayEntity).GetProperty(nameof(ArrayEntity.IntList));
+ = typeof(ArrayEntity).GetProperty(nameof(ArrayEntity.IntList))!;
private static readonly PropertyInfo NullableIntList
- = typeof(ArrayEntity).GetProperty(nameof(ArrayEntity.NullableIntList));
+ = typeof(ArrayEntity).GetProperty(nameof(ArrayEntity.NullableIntList))!;
private static readonly PropertyInfo StringArray
- = typeof(ArrayEntity).GetProperty(nameof(ArrayEntity.StringArray));
+ = typeof(ArrayEntity).GetProperty(nameof(ArrayEntity.StringArray))!;
private static readonly PropertyInfo NullableStringArray
- = typeof(ArrayEntity).GetProperty(nameof(ArrayEntity.NullableStringArray));
+ = typeof(ArrayEntity).GetProperty(nameof(ArrayEntity.NullableStringArray))!;
private static readonly PropertyInfo StringList
- = typeof(ArrayEntity).GetProperty(nameof(ArrayEntity.StringList));
+ = typeof(ArrayEntity).GetProperty(nameof(ArrayEntity.StringList))!;
private static readonly PropertyInfo NullableStringList
- = typeof(ArrayEntity).GetProperty(nameof(ArrayEntity.NullableStringList));
+ = typeof(ArrayEntity).GetProperty(nameof(ArrayEntity.NullableStringList))!;
private static readonly PropertyInfo ValueConvertedArrayOfEnum
- = typeof(ArrayEntity).GetProperty(nameof(ArrayEntity.ValueConvertedArrayOfEnum));
+ = typeof(ArrayEntity).GetProperty(nameof(ArrayEntity.ValueConvertedArrayOfEnum))!;
private static readonly PropertyInfo ValueConvertedListOfEnum
- = typeof(ArrayEntity).GetProperty(nameof(ArrayEntity.ValueConvertedListOfEnum));
+ = typeof(ArrayEntity).GetProperty(nameof(ArrayEntity.ValueConvertedListOfEnum))!;
protected override Expression VisitMember(MemberExpression node)
{
diff --git a/test/EFCore.PG.FunctionalTests/Query/ArrayQueryFixture.cs b/test/EFCore.PG.FunctionalTests/Query/ArrayQueryFixture.cs
index 1809ce560..7a0e02122 100644
--- a/test/EFCore.PG.FunctionalTests/Query/ArrayQueryFixture.cs
+++ b/test/EFCore.PG.FunctionalTests/Query/ArrayQueryFixture.cs
@@ -11,7 +11,7 @@ protected override ITestStoreFactory TestStoreFactory
public TestSqlLoggerFactory TestSqlLoggerFactory
=> (TestSqlLoggerFactory)ListLoggerFactory;
- private ArrayQueryData _expectedData;
+ private ArrayQueryData? _expectedData;
public override DbContextOptionsBuilder AddOptions(DbContextOptionsBuilder builder)
=> base.AddOptions(builder).ConfigureWarnings(wcb => wcb.Ignore(CoreEventId.CollectionWithoutComparer));
@@ -26,9 +26,9 @@ public ISetSource GetExpectedData()
=> _expectedData ??= new ArrayQueryData();
public IReadOnlyDictionary EntitySorters
- => new Dictionary>
+ => new Dictionary>
{
- { typeof(ArrayEntity), e => ((ArrayEntity)e)?.Id }, { typeof(ArrayContainerEntity), e => ((ArrayContainerEntity)e)?.Id }
+ { typeof(ArrayEntity), e => ((ArrayEntity)e).Id }, { typeof(ArrayContainerEntity), e => ((ArrayContainerEntity)e)?.Id }
}.ToDictionary(e => e.Key, e => (object)e.Value);
public IReadOnlyDictionary EntityAsserters
@@ -38,7 +38,8 @@ public IReadOnlyDictionary EntityAsserters
typeof(ArrayEntity), (e, a) =>
{
Assert.Equal(e is null, a is null);
- if (a is not null)
+
+ if (e is not null && a is not null)
{
var ee = (ArrayEntity)e;
var aa = (ArrayEntity)a;
@@ -69,7 +70,8 @@ public IReadOnlyDictionary EntityAsserters
typeof(ArrayContainerEntity), (e, a) =>
{
Assert.Equal(e is null, a is null);
- if (a is not null)
+
+ if (e is not null && a is not null)
{
var ee = (ArrayContainerEntity)e;
var aa = (ArrayContainerEntity)a;
diff --git a/test/EFCore.PG.FunctionalTests/Query/ArrayQueryTest.cs b/test/EFCore.PG.FunctionalTests/Query/ArrayQueryTest.cs
index 1951cd85e..a970c8c3f 100644
--- a/test/EFCore.PG.FunctionalTests/Query/ArrayQueryTest.cs
+++ b/test/EFCore.PG.FunctionalTests/Query/ArrayQueryTest.cs
@@ -377,7 +377,7 @@ await AssertQuery(
async,
ss => ss.Set().Select(e => new[] { e.NullableText, e.NonNullableText }),
elementAsserter: Assert.Equal,
- elementSorter: strings => strings != null ? string.Join(separator: "", strings) : null);
+ elementSorter: strings => strings != null ? string.Join(separator: "", strings) : "");
AssertSql(
"""
@@ -412,7 +412,7 @@ await AssertQuery(
async,
ss => ss.Set().Select(e => new[] { e.Varchar10, e.Varchar15 }),
elementAsserter: Assert.Equal,
- elementSorter: strings => strings != null ? string.Join(separator: "", strings) : null);
+ elementSorter: strings => strings != null ? string.Join(separator: "", strings) : "");
AssertSql(
"""
@@ -429,7 +429,7 @@ await AssertQuery(
async,
ss => ss.Set().Select(e => new[] { e.NonNullableText, e.Varchar15 }),
elementAsserter: Assert.Equal,
- elementSorter: strings => strings != null ? string.Join(separator: "", strings) : null);
+ elementSorter: strings => strings != null ? string.Join(separator: "", strings) : "");
AssertSql(
"""
@@ -446,7 +446,7 @@ await AssertQuery(
async,
ss => ss.Set().Select(e => new[] { e.Id.ToString(), e.Varchar15 }),
elementAsserter: Assert.Equal,
- elementSorter: strings => strings != null ? string.Join(separator: "", strings) : null);
+ elementSorter: strings => strings != null ? string.Join(separator: "", strings) : "");
AssertSql(
"""
@@ -463,7 +463,7 @@ await AssertQuery(
async,
ss => ss.Set().Select(e => new[] { e.NonNullableText, e.NullableText ?? "" }),
elementAsserter: Assert.Equal,
- elementSorter: strings => strings != null ? string.Join(separator: "", strings) : null);
+ elementSorter: strings => strings != null ? string.Join(separator: "", strings) : "");
AssertSql(
"""
diff --git a/test/EFCore.PG.FunctionalTests/Query/CharacterQueryNpgsqlTest.cs b/test/EFCore.PG.FunctionalTests/Query/CharacterQueryNpgsqlTest.cs
index cc248e83a..2799f008d 100644
--- a/test/EFCore.PG.FunctionalTests/Query/CharacterQueryNpgsqlTest.cs
+++ b/test/EFCore.PG.FunctionalTests/Query/CharacterQueryNpgsqlTest.cs
@@ -41,10 +41,10 @@ public void Find_in_database()
m2.Character6 = update;
ctx.SaveChanges();
- var item0 = ctx.CharacterTestEntities.Find("12345678").Character6;
+ var item0 = ctx.CharacterTestEntities.Find("12345678")!.Character6;
Assert.Equal(update, item0);
- var item1 = ctx.CharacterTestEntities.Find("123456 ").Character6;
+ var item1 = ctx.CharacterTestEntities.Find("123456 ")!.Character6;
Assert.Equal(update, item1);
}
}
@@ -62,18 +62,18 @@ public void Find_locally_available()
const string update = "update";
- var m1 = ctx.CharacterTestEntities.Find("12345678");
+ var m1 = ctx.CharacterTestEntities.Find("12345678")!;
m1.Character6 = update;
ctx.SaveChanges();
- var m2 = ctx.CharacterTestEntities.Find("123456 ");
+ var m2 = ctx.CharacterTestEntities.Find("123456 ")!;
m2.Character6 = update;
ctx.SaveChanges();
- var item0 = ctx.CharacterTestEntities.Find("12345678").Character6;
+ var item0 = ctx.CharacterTestEntities.Find("12345678")!.Character6;
Assert.Equal(update, item0);
- var item1 = ctx.CharacterTestEntities.Find("123456 ").Character6;
+ var item1 = ctx.CharacterTestEntities.Find("123456 ")!.Character6;
Assert.Equal(update, item1);
}
@@ -92,11 +92,11 @@ public void Test_change_tracking()
ctx.CharacterTestEntities.Add(new CharacterTestEntity { Character8 = "123456 " });
ctx.SaveChanges();
- var m1 = ctx.CharacterTestEntities.Find("12345678");
+ var m1 = ctx.CharacterTestEntities.Find("12345678")!;
m1.Character6 = update;
ctx.SaveChanges();
- var m2 = ctx.CharacterTestEntities.Find("123456 ");
+ var m2 = ctx.CharacterTestEntities.Find("123456 ")!;
m2.Character6 = update;
ctx.SaveChanges();
}
@@ -178,8 +178,8 @@ public void ClearEntities()
public class CharacterTestEntity
{
- public string Character8 { get; set; }
- public string Character6 { get; set; }
+ public string? Character8 { get; set; }
+ public string? Character6 { get; set; }
}
public class CharacterContext : PoolableDbContext
diff --git a/test/EFCore.PG.FunctionalTests/Query/CompatibilityQueryNpgsqlTest.cs b/test/EFCore.PG.FunctionalTests/Query/CompatibilityQueryNpgsqlTest.cs
index 0e20d87fc..783644184 100644
--- a/test/EFCore.PG.FunctionalTests/Query/CompatibilityQueryNpgsqlTest.cs
+++ b/test/EFCore.PG.FunctionalTests/Query/CompatibilityQueryNpgsqlTest.cs
@@ -34,7 +34,7 @@ LIMIT 2
#region Support
- private CompatibilityContext CreateContext(Version postgresVersion = null)
+ private CompatibilityContext CreateContext(Version? postgresVersion = null)
=> Fixture.CreateContext(postgresVersion);
private CompatibilityContext CreateRedshiftContext()
@@ -42,7 +42,7 @@ private CompatibilityContext CreateRedshiftContext()
public class CompatibilityQueryNpgsqlFixture : FixtureBase, IDisposable, IAsyncLifetime
{
- private TestStore _testStore;
+ private TestStore _testStore = null!;
private const string StoreName = "CompatibilityTest";
private readonly ListLoggerFactory _listLoggerFactory = NpgsqlTestStoreFactory.Instance.CreateListLoggerFactory(_ => false);
@@ -53,7 +53,7 @@ public TestSqlLoggerFactory TestSqlLoggerFactory
public virtual CompatibilityContext CreateContext()
=> CreateContext(null);
- public virtual CompatibilityContext CreateContext(Version postgresVersion)
+ public virtual CompatibilityContext CreateContext(Version? postgresVersion)
{
var builder = new DbContextOptionsBuilder();
_testStore.AddProviderOptions(builder);
diff --git a/test/EFCore.PG.FunctionalTests/Query/FunkyDataQueryNpgsqlTest.cs b/test/EFCore.PG.FunctionalTests/Query/FunkyDataQueryNpgsqlTest.cs
index fb7483f05..324c42bbe 100644
--- a/test/EFCore.PG.FunctionalTests/Query/FunkyDataQueryNpgsqlTest.cs
+++ b/test/EFCore.PG.FunctionalTests/Query/FunkyDataQueryNpgsqlTest.cs
@@ -40,7 +40,7 @@ private void AssertSql(params string[] expected)
public class FunkyDataQueryNpgsqlFixture : FunkyDataQueryFixtureBase, ITestSqlLoggerFactory
{
- private FunkyDataData _expectedData;
+ private FunkyDataData? _expectedData;
public TestSqlLoggerFactory TestSqlLoggerFactory
=> (TestSqlLoggerFactory)ListLoggerFactory;
diff --git a/test/EFCore.PG.FunctionalTests/Query/FuzzyStringMatchQueryNpgsqlTest.cs b/test/EFCore.PG.FunctionalTests/Query/FuzzyStringMatchQueryNpgsqlTest.cs
index fd76749d3..70fda57a9 100644
--- a/test/EFCore.PG.FunctionalTests/Query/FuzzyStringMatchQueryNpgsqlTest.cs
+++ b/test/EFCore.PG.FunctionalTests/Query/FuzzyStringMatchQueryNpgsqlTest.cs
@@ -159,7 +159,7 @@ public class FuzzyStringMatchTestEntity
///
/// Some text.
///
- public string Text { get; set; }
+ public string Text { get; set; } = null!;
}
///
diff --git a/test/EFCore.PG.FunctionalTests/Query/GearsOfWarQueryNpgsqlFixture.cs b/test/EFCore.PG.FunctionalTests/Query/GearsOfWarQueryNpgsqlFixture.cs
index 19f6da3ea..3b7987625 100644
--- a/test/EFCore.PG.FunctionalTests/Query/GearsOfWarQueryNpgsqlFixture.cs
+++ b/test/EFCore.PG.FunctionalTests/Query/GearsOfWarQueryNpgsqlFixture.cs
@@ -3,6 +3,7 @@
namespace Npgsql.EntityFrameworkCore.PostgreSQL.Query;
+
public class GearsOfWarQueryNpgsqlFixture : GearsOfWarQueryRelationalFixture
{
protected override string StoreName
@@ -11,7 +12,7 @@ protected override string StoreName
protected override ITestStoreFactory TestStoreFactory
=> NpgsqlTestStoreFactory.Instance;
- private GearsOfWarData _expectedData;
+ private GearsOfWarData? _expectedData;
static GearsOfWarQueryNpgsqlFixture()
{
diff --git a/test/EFCore.PG.FunctionalTests/Query/JsonDomQueryTest.cs b/test/EFCore.PG.FunctionalTests/Query/JsonDomQueryTest.cs
index 00132db3a..5def3a621 100644
--- a/test/EFCore.PG.FunctionalTests/Query/JsonDomQueryTest.cs
+++ b/test/EFCore.PG.FunctionalTests/Query/JsonDomQueryTest.cs
@@ -73,7 +73,7 @@ public void Parameter_document()
{
using var ctx = CreateContext();
- var expected = ctx.JsonbEntities.Find(1).CustomerDocument;
+ var expected = ctx.JsonbEntities.Find(1)!.CustomerDocument;
var actual = ctx.JsonbEntities.Single(e => e.CustomerDocument == expected).CustomerDocument;
Assert.Equal(actual, expected);
@@ -103,7 +103,7 @@ public void Parameter_element()
{
using var ctx = CreateContext();
- var expected = ctx.JsonbEntities.Find(1).CustomerElement;
+ var expected = ctx.JsonbEntities.Find(1)!.CustomerElement;
var actual = ctx.JsonbEntities.Single(e => e.CustomerElement.Equals(expected)).CustomerElement;
Assert.Equal(actual, expected);
@@ -374,7 +374,7 @@ public void Like()
{
using var ctx = CreateContext();
- var x = ctx.JsonbEntities.Single(e => e.CustomerElement.GetProperty("Name").GetString().StartsWith("J"));
+ var x = ctx.JsonbEntities.Single(e => e.CustomerElement.GetProperty("Name").GetString()!.StartsWith("J"));
Assert.Equal("Joe", x.CustomerElement.GetProperty("Name").GetString());
@@ -744,7 +744,7 @@ public class JsonbEntity
{
public int Id { get; set; }
- public JsonDocument CustomerDocument { get; set; }
+ public JsonDocument CustomerDocument { get; set; } = null!;
public JsonElement CustomerElement { get; set; }
}
@@ -753,7 +753,7 @@ public class JsonEntity
public int Id { get; set; }
[Column(TypeName = "json")]
- public JsonDocument CustomerDocument { get; set; }
+ public JsonDocument CustomerDocument { get; set; } = null!;
[Column(TypeName = "json")]
public JsonElement CustomerElement { get; set; }
diff --git a/test/EFCore.PG.FunctionalTests/Query/JsonPocoQueryTest.cs b/test/EFCore.PG.FunctionalTests/Query/JsonPocoQueryTest.cs
index 5011584ed..34cd1d173 100644
--- a/test/EFCore.PG.FunctionalTests/Query/JsonPocoQueryTest.cs
+++ b/test/EFCore.PG.FunctionalTests/Query/JsonPocoQueryTest.cs
@@ -57,7 +57,7 @@ public void Parameter()
{
using var ctx = CreateContext();
- var expected = ctx.JsonbEntities.Find(1).Customer;
+ var expected = ctx.JsonbEntities.Find(1)!.Customer;
var actual = ctx.JsonbEntities.Single(e => e.Customer == expected).Customer;
Assert.Equal(actual.Name, expected.Name);
@@ -718,7 +718,7 @@ public static async Task SeedAsync(JsonPocoQueryContext context)
Customer = CreateCustomer1(),
ToplevelArray = ["one", "two", "three"]
},
- new JsonbEntity { Id = 2, Customer = CreateCustomer2() });
+ new JsonbEntity { Id = 2, Customer = CreateCustomer2(), ToplevelArray = [] });
context.JsonEntities.AddRange(
new JsonEntity
{
@@ -726,7 +726,7 @@ public static async Task SeedAsync(JsonPocoQueryContext context)
Customer = CreateCustomer1(),
ToplevelArray = ["one", "two", "three"]
},
- new JsonEntity { Id = 2, Customer = CreateCustomer2() });
+ new JsonEntity { Id = 2, Customer = CreateCustomer2(), ToplevelArray = [] });
await context.SaveChangesAsync();
@@ -826,10 +826,10 @@ public class JsonbEntity
public int Id { get; set; }
[Column(TypeName = "jsonb")]
- public Customer Customer { get; set; }
+ public required Customer Customer { get; set; }
[Column(TypeName = "jsonb")]
- public string[] ToplevelArray { get; set; }
+ public required string[] ToplevelArray { get; set; }
}
public class JsonEntity
@@ -837,10 +837,10 @@ public class JsonEntity
public int Id { get; set; }
[Column(TypeName = "json")]
- public Customer Customer { get; set; }
+ public required Customer Customer { get; set; }
[Column(TypeName = "json")]
- public string[] ToplevelArray { get; set; }
+ public required string[] ToplevelArray { get; set; }
}
public class JsonPocoQueryFixture : SharedStoreFixtureBase
@@ -868,43 +868,43 @@ protected override Task SeedAsync(JsonPocoQueryContext context)
public class Customer
{
- public string Name { get; set; }
+ public required string Name { get; set; }
public int Age { get; set; }
public Guid ID { get; set; }
[JsonPropertyName("is_vip")]
public bool IsVip { get; set; }
- public Statistics Statistics { get; set; }
- public Order[] Orders { get; set; }
- public VariousTypes VariousTypes { get; set; }
+ public Statistics Statistics { get; set; } = null!;
+ public Order[] Orders { get; set; } = null!;
+ public VariousTypes VariousTypes { get; set; } = null!;
}
public class Statistics
{
public long Visits { get; set; }
public int Purchases { get; set; }
- public NestedStatistics Nested { get; set; }
+ public required NestedStatistics Nested { get; set; }
}
public class NestedStatistics
{
public int SomeProperty { get; set; }
public int? SomeNullableInt { get; set; }
- public int[] IntArray { get; set; }
- public List IntList { get; set; }
+ public int[] IntArray { get; set; } = null!;
+ public List IntList { get; set; } = null!;
public Guid? SomeNullableGuid { get; set; }
}
public class Order
{
public decimal Price { get; set; }
- public string ShippingAddress { get; set; }
+ public string ShippingAddress { get; set; } = null!;
}
public class VariousTypes
{
- public string String { get; set; }
+ public string String { get; set; } = null!;
public int Int16 { get; set; }
public int Int32 { get; set; }
public int Int64 { get; set; }
diff --git a/test/EFCore.PG.FunctionalTests/Query/JsonQueryNpgsqlTest.cs b/test/EFCore.PG.FunctionalTests/Query/JsonQueryNpgsqlTest.cs
index 1f7d6cdb1..f9fb47da7 100644
--- a/test/EFCore.PG.FunctionalTests/Query/JsonQueryNpgsqlTest.cs
+++ b/test/EFCore.PG.FunctionalTests/Query/JsonQueryNpgsqlTest.cs
@@ -3398,7 +3398,7 @@ public class JsonQueryNpgsqlFixture : JsonQueryRelationalFixture, IQueryFixtureB
protected override ITestStoreFactory TestStoreFactory
=> NpgsqlTestStoreFactory.Instance;
- private JsonQueryData _expectedData;
+ private JsonQueryData? _expectedData;
private readonly IReadOnlyDictionary _entityAsserters;
public JsonQueryNpgsqlFixture()
@@ -3407,8 +3407,9 @@ public JsonQueryNpgsqlFixture()
entityAsserters[typeof(JsonEntityAllTypes)] = (object e, object a) =>
{
- Assert.Equal(e == null, a == null);
- if (a != null)
+ Assert.Equal(e is null, a is null);
+
+ if (e is not null && a is not null)
{
var ee = (JsonEntityAllTypes)e;
var aa = (JsonEntityAllTypes)a;
@@ -3418,17 +3419,18 @@ public JsonQueryNpgsqlFixture()
AssertAllTypes(ee.Reference, aa.Reference);
Assert.Equal(ee.Collection?.Count ?? 0, aa.Collection?.Count ?? 0);
- for (var i = 0; i < ee.Collection.Count; i++)
+ for (var i = 0; i < ee.Collection!.Count; i++)
{
- AssertAllTypes(ee.Collection[i], aa.Collection[i]);
+ AssertAllTypes(ee.Collection[i], aa.Collection![i]);
}
}
};
entityAsserters[typeof(JsonOwnedAllTypes)] = (object e, object a) =>
{
- Assert.Equal(e == null, a == null);
- if (a != null)
+ Assert.Equal(e is null, a is null);
+
+ if (e is not null && a is not null)
{
var ee = (JsonOwnedAllTypes)e;
var aa = (JsonOwnedAllTypes)a;
diff --git a/test/EFCore.PG.FunctionalTests/Query/JsonStringQueryTest.cs b/test/EFCore.PG.FunctionalTests/Query/JsonStringQueryTest.cs
index 03be46212..7ecbcbab0 100644
--- a/test/EFCore.PG.FunctionalTests/Query/JsonStringQueryTest.cs
+++ b/test/EFCore.PG.FunctionalTests/Query/JsonStringQueryTest.cs
@@ -67,7 +67,7 @@ public void Parameter()
{
using var ctx = CreateContext();
- var expected = ctx.JsonEntities.Find(1).CustomerJsonb;
+ var expected = ctx.JsonEntities.Find(1)!.CustomerJsonb;
var actual = ctx.JsonEntities.Single(e => e.CustomerJsonb == expected).CustomerJsonb;
Assert.Equal(actual, expected);
@@ -349,12 +349,12 @@ public class JsonEntity
public int Id { get; set; }
[Column(TypeName = "jsonb")]
- public string CustomerJsonb { get; set; }
+ public string CustomerJsonb { get; set; } = null!;
[Column(TypeName = "json")]
- public string CustomerJson { get; set; }
+ public string CustomerJson { get; set; } = null!;
- public string SomeString { get; set; }
+ public string? SomeString { get; set; }
}
public class JsonStringQueryFixture : SharedStoreFixtureBase
diff --git a/test/EFCore.PG.FunctionalTests/Query/LegacyNpgsqlNodaTimeTypeMappingTest.cs b/test/EFCore.PG.FunctionalTests/Query/LegacyNpgsqlNodaTimeTypeMappingTest.cs
index e2a5bb1f0..2a99bbcd5 100644
--- a/test/EFCore.PG.FunctionalTests/Query/LegacyNpgsqlNodaTimeTypeMappingTest.cs
+++ b/test/EFCore.PG.FunctionalTests/Query/LegacyNpgsqlNodaTimeTypeMappingTest.cs
@@ -14,11 +14,11 @@ public class LegacyNpgsqlNodaTimeTypeMappingTest
{
[Fact]
public void Timestamp_maps_to_Instant_by_default()
- => Assert.Same(typeof(Instant), GetMapping("timestamp without time zone").ClrType);
+ => Assert.Same(typeof(Instant), GetMapping("timestamp without time zone")!.ClrType);
[Fact]
public void Timestamptz_maps_to_Instant_by_default()
- => Assert.Same(typeof(Instant), GetMapping("timestamp with time zone").ClrType);
+ => Assert.Same(typeof(Instant), GetMapping("timestamp with time zone")!.ClrType);
[Fact]
public void LocalDateTime_does_not_map_to_timestamptz()
@@ -27,7 +27,7 @@ public void LocalDateTime_does_not_map_to_timestamptz()
[Fact]
public void GenerateSqlLiteral_returns_instant_literal()
{
- var mapping = GetMapping(typeof(Instant));
+ var mapping = GetMapping(typeof(Instant))!;
Assert.Equal("timestamp without time zone", mapping.StoreType);
var instant = (new LocalDateTime(2018, 4, 20, 10, 31, 33, 666) + Period.FromTicks(6660)).InUtc().ToInstant();
@@ -37,7 +37,7 @@ public void GenerateSqlLiteral_returns_instant_literal()
[Fact]
public void GenerateSqlLiteral_returns_instant_infinity_literal()
{
- var mapping = GetMapping(typeof(Instant));
+ var mapping = GetMapping(typeof(Instant))!;
Assert.Equal(typeof(Instant), mapping.ClrType);
Assert.Equal("timestamp without time zone", mapping.StoreType);
@@ -48,7 +48,7 @@ public void GenerateSqlLiteral_returns_instant_infinity_literal()
[Fact]
public void GenerateSqlLiteral_returns_instant_range_in_legacy_mode()
{
- var mapping = (NpgsqlRangeTypeMapping)GetMapping(typeof(NpgsqlRange));
+ var mapping = (NpgsqlRangeTypeMapping)GetMapping(typeof(NpgsqlRange))!;
Assert.Equal("tsrange", mapping.StoreType);
Assert.Equal("timestamp without time zone", mapping.SubtypeMapping.StoreType);
@@ -74,13 +74,13 @@ public void GenerateSqlLiteral_returns_instant_range_in_legacy_mode()
new NpgsqlSingletonOptions()
);
- private static RelationalTypeMapping GetMapping(string storeType)
+ private static RelationalTypeMapping? GetMapping(string storeType)
=> Mapper.FindMapping(storeType);
- private static RelationalTypeMapping GetMapping(Type clrType)
+ private static RelationalTypeMapping? GetMapping(Type clrType)
=> Mapper.FindMapping(clrType);
- private static RelationalTypeMapping GetMapping(Type clrType, string storeType)
+ private static RelationalTypeMapping? GetMapping(Type clrType, string storeType)
=> Mapper.FindMapping(clrType, storeType);
private class LegacyNpgsqlNodaTimeTypeMappingFixture : IDisposable
diff --git a/test/EFCore.PG.FunctionalTests/Query/NavigationTest.cs b/test/EFCore.PG.FunctionalTests/Query/NavigationTest.cs
index bb9e565e5..eadfaf07c 100644
--- a/test/EFCore.PG.FunctionalTests/Query/NavigationTest.cs
+++ b/test/EFCore.PG.FunctionalTests/Query/NavigationTest.cs
@@ -2,6 +2,8 @@
namespace Npgsql.EntityFrameworkCore.PostgreSQL.Query;
+#nullable disable
+
public class NavigationTest(NavigationTestFixture fixture) : IClassFixture
{
[Fact]
diff --git a/test/EFCore.PG.FunctionalTests/Query/NorthwindDbFunctionsQueryNpgsqlTest.cs b/test/EFCore.PG.FunctionalTests/Query/NorthwindDbFunctionsQueryNpgsqlTest.cs
index 425b5782e..2a3f2d613 100644
--- a/test/EFCore.PG.FunctionalTests/Query/NorthwindDbFunctionsQueryNpgsqlTest.cs
+++ b/test/EFCore.PG.FunctionalTests/Query/NorthwindDbFunctionsQueryNpgsqlTest.cs
@@ -3,6 +3,8 @@
namespace Npgsql.EntityFrameworkCore.PostgreSQL.Query;
+#nullable disable
+
public class NorthwindDbFunctionsQueryNpgsqlTest : NorthwindDbFunctionsQueryRelationalTestBase<
NorthwindQueryNpgsqlFixture>
{
diff --git a/test/EFCore.PG.FunctionalTests/Query/NorthwindFunctionsQueryNpgsqlTest.cs b/test/EFCore.PG.FunctionalTests/Query/NorthwindFunctionsQueryNpgsqlTest.cs
index fc6ecc4a5..25d15646d 100644
--- a/test/EFCore.PG.FunctionalTests/Query/NorthwindFunctionsQueryNpgsqlTest.cs
+++ b/test/EFCore.PG.FunctionalTests/Query/NorthwindFunctionsQueryNpgsqlTest.cs
@@ -5,6 +5,8 @@
namespace Npgsql.EntityFrameworkCore.PostgreSQL.Query;
+#nullable disable
+
public class NorthwindFunctionsQueryNpgsqlTest : NorthwindFunctionsQueryRelationalTestBase>
{
// ReSharper disable once UnusedParameter.Local
diff --git a/test/EFCore.PG.FunctionalTests/Query/NorthwindMiscellaneousQueryNpgsqlTest.cs b/test/EFCore.PG.FunctionalTests/Query/NorthwindMiscellaneousQueryNpgsqlTest.cs
index 0374ac3b4..08dcc031e 100644
--- a/test/EFCore.PG.FunctionalTests/Query/NorthwindMiscellaneousQueryNpgsqlTest.cs
+++ b/test/EFCore.PG.FunctionalTests/Query/NorthwindMiscellaneousQueryNpgsqlTest.cs
@@ -3,6 +3,8 @@
namespace Npgsql.EntityFrameworkCore.PostgreSQL.Query;
+#nullable disable
+
public class NorthwindMiscellaneousQueryNpgsqlTest : NorthwindMiscellaneousQueryRelationalTestBase<
NorthwindQueryNpgsqlFixture>
{
diff --git a/test/EFCore.PG.FunctionalTests/Query/QueryBugTest.cs b/test/EFCore.PG.FunctionalTests/Query/QueryBugTest.cs
index 3dd78fa0d..118c30c85 100644
--- a/test/EFCore.PG.FunctionalTests/Query/QueryBugTest.cs
+++ b/test/EFCore.PG.FunctionalTests/Query/QueryBugTest.cs
@@ -5,6 +5,8 @@
namespace Npgsql.EntityFrameworkCore.PostgreSQL.Query;
+#nullable disable
+
public class QueryBugsTest : IClassFixture
{
// ReSharper disable once UnusedParameter.Local
diff --git a/test/EFCore.PG.FunctionalTests/Query/SpatialQueryNpgsqlGeographyTest.cs b/test/EFCore.PG.FunctionalTests/Query/SpatialQueryNpgsqlGeographyTest.cs
index e7f0505e5..db42449b4 100644
--- a/test/EFCore.PG.FunctionalTests/Query/SpatialQueryNpgsqlGeographyTest.cs
+++ b/test/EFCore.PG.FunctionalTests/Query/SpatialQueryNpgsqlGeographyTest.cs
@@ -6,6 +6,8 @@
namespace Npgsql.EntityFrameworkCore.PostgreSQL.Query;
+#nullable disable
+
// ReSharper disable once UnusedMember.Global
[RequiresPostgis]
public class SpatialQueryNpgsqlGeographyTest
diff --git a/test/EFCore.PG.FunctionalTests/Query/SpatialQueryNpgsqlGeometryTest.cs b/test/EFCore.PG.FunctionalTests/Query/SpatialQueryNpgsqlGeometryTest.cs
index 03cc231b7..8d3c10557 100644
--- a/test/EFCore.PG.FunctionalTests/Query/SpatialQueryNpgsqlGeometryTest.cs
+++ b/test/EFCore.PG.FunctionalTests/Query/SpatialQueryNpgsqlGeometryTest.cs
@@ -5,6 +5,8 @@
namespace Npgsql.EntityFrameworkCore.PostgreSQL.Query;
+#nullable disable
+
[RequiresPostgis]
public class SpatialQueryNpgsqlGeometryTest
: SpatialQueryRelationalTestBase
diff --git a/test/EFCore.PG.FunctionalTests/Query/SqlQueryNpgsqlTest.cs b/test/EFCore.PG.FunctionalTests/Query/SqlQueryNpgsqlTest.cs
index 692771726..99b7ab1d7 100644
--- a/test/EFCore.PG.FunctionalTests/Query/SqlQueryNpgsqlTest.cs
+++ b/test/EFCore.PG.FunctionalTests/Query/SqlQueryNpgsqlTest.cs
@@ -70,7 +70,9 @@ public override async Task SqlQueryRaw_queryable_composed_after_removing_whitesp
SELECT m."Address", m."City", m."CompanyName", m."ContactName", m."ContactTitle", m."Country", m."CustomerID", m."Fax", m."Phone", m."Region", m."PostalCode"
FROM (
-
+
+""" + " " + """
+
SELECT
@@ -279,7 +281,7 @@ public override async Task SqlQueryRaw_queryable_with_null_parameter(bool async)
""");
}
- public override async Task SqlQueryRaw_queryable_with_parameters_and_closure(bool async)
+ public override async Task SqlQueryRaw_queryable_with_parameters_and_closure(bool async)
{
var queryString = await base.SqlQueryRaw_queryable_with_parameters_and_closure(async);
diff --git a/test/EFCore.PG.FunctionalTests/Query/TPCGearsOfWarQueryNpgsqlFixture.cs b/test/EFCore.PG.FunctionalTests/Query/TPCGearsOfWarQueryNpgsqlFixture.cs
index 1e5de06b5..d59268cc3 100644
--- a/test/EFCore.PG.FunctionalTests/Query/TPCGearsOfWarQueryNpgsqlFixture.cs
+++ b/test/EFCore.PG.FunctionalTests/Query/TPCGearsOfWarQueryNpgsqlFixture.cs
@@ -26,7 +26,7 @@ protected override void OnModelCreating(ModelBuilder modelBuilder, DbContext con
modelBuilder.Entity().Property(g => g.Location).HasColumnType("varchar(100)");
}
- private GearsOfWarData _expectedData;
+ private GearsOfWarData? _expectedData;
public override ISetSource GetExpectedData()
{
diff --git a/test/EFCore.PG.FunctionalTests/Query/TPTGearsOfWarQueryNpgsqlFixture.cs b/test/EFCore.PG.FunctionalTests/Query/TPTGearsOfWarQueryNpgsqlFixture.cs
index 1011a5061..a55022b0a 100644
--- a/test/EFCore.PG.FunctionalTests/Query/TPTGearsOfWarQueryNpgsqlFixture.cs
+++ b/test/EFCore.PG.FunctionalTests/Query/TPTGearsOfWarQueryNpgsqlFixture.cs
@@ -26,7 +26,7 @@ protected override void OnModelCreating(ModelBuilder modelBuilder, DbContext con
modelBuilder.Entity().Property(g => g.Location).HasColumnType("varchar(100)");
}
- private GearsOfWarData _expectedData;
+ private GearsOfWarData? _expectedData;
public override ISetSource GetExpectedData()
{
diff --git a/test/EFCore.PG.FunctionalTests/Query/Translations/BasicTypesQueryNpgsqlFixture.cs b/test/EFCore.PG.FunctionalTests/Query/Translations/BasicTypesQueryNpgsqlFixture.cs
index 03140627c..ae2b49f1e 100644
--- a/test/EFCore.PG.FunctionalTests/Query/Translations/BasicTypesQueryNpgsqlFixture.cs
+++ b/test/EFCore.PG.FunctionalTests/Query/Translations/BasicTypesQueryNpgsqlFixture.cs
@@ -2,8 +2,6 @@
using Npgsql.EntityFrameworkCore.PostgreSQL.Infrastructure;
using Npgsql.EntityFrameworkCore.PostgreSQL.TestUtilities;
-#nullable enable
-
namespace Microsoft.EntityFrameworkCore.Query.Translations;
public class BasicTypesQueryNpgsqlFixture : BasicTypesQueryFixtureBase, ITestSqlLoggerFactory
diff --git a/test/EFCore.PG.FunctionalTests/Query/Translations/BigIntegerTranslationsTest.cs b/test/EFCore.PG.FunctionalTests/Query/Translations/BigIntegerTranslationsTest.cs
index 550ab373f..820436f63 100644
--- a/test/EFCore.PG.FunctionalTests/Query/Translations/BigIntegerTranslationsTest.cs
+++ b/test/EFCore.PG.FunctionalTests/Query/Translations/BigIntegerTranslationsTest.cs
@@ -147,7 +147,7 @@ public class Entity
public class BigIntegerQueryFixture : SharedStoreFixtureBase, IQueryFixtureBase, ITestSqlLoggerFactory
{
- private BigIntegerData _expectedData;
+ private BigIntegerData? _expectedData;
protected override string StoreName
=> "BigIntegerQueryTest";
@@ -168,7 +168,7 @@ public ISetSource GetExpectedData()
=> _expectedData ??= new BigIntegerData();
public IReadOnlyDictionary EntitySorters
- => new Dictionary> { { typeof(Entity), e => ((Entity)e)?.Id } }
+ => new Dictionary> { { typeof(Entity), e => ((Entity)e).Id } }
.ToDictionary(e => e.Key, e => (object)e.Value);
public IReadOnlyDictionary EntityAsserters
@@ -178,9 +178,10 @@ public IReadOnlyDictionary EntityAsserters
typeof(Entity), (e, a) =>
{
Assert.Equal(e is null, a is null);
+
if (a is not null)
{
- var ee = (Entity)e;
+ var ee = (Entity)e!;
var aa = (Entity)a;
Assert.Equal(ee.Id, aa.Id);
diff --git a/test/EFCore.PG.FunctionalTests/Query/Translations/CitextTranslationsTest.cs b/test/EFCore.PG.FunctionalTests/Query/Translations/CitextTranslationsTest.cs
index 48b5bac58..a8d515923 100644
--- a/test/EFCore.PG.FunctionalTests/Query/Translations/CitextTranslationsTest.cs
+++ b/test/EFCore.PG.FunctionalTests/Query/Translations/CitextTranslationsTest.cs
@@ -67,7 +67,7 @@ public void StartsWith_param_instance()
SELECT s."Id", s."CaseInsensitiveText"
FROM "SomeEntities" AS s
-WHERE s."CaseInsensitiveText" IS NOT NULL AND left(@param, length(s."CaseInsensitiveText"))::citext = s."CaseInsensitiveText"
+WHERE left(@param, length(s."CaseInsensitiveText"))::citext = s."CaseInsensitiveText"
LIMIT 2
""");
}
@@ -121,7 +121,7 @@ public void EndsWith_param_instance()
SELECT s."Id", s."CaseInsensitiveText"
FROM "SomeEntities" AS s
-WHERE s."CaseInsensitiveText" IS NOT NULL AND right(@param, length(s."CaseInsensitiveText"))::citext = s."CaseInsensitiveText"
+WHERE right(@param, length(s."CaseInsensitiveText"))::citext = s."CaseInsensitiveText"
LIMIT 2
""");
}
@@ -175,7 +175,7 @@ public void Contains_param_instance()
SELECT s."Id", s."CaseInsensitiveText"
FROM "SomeEntities" AS s
-WHERE s."CaseInsensitiveText" IS NOT NULL AND strpos(@param, s."CaseInsensitiveText") > 0
+WHERE strpos(@param, s."CaseInsensitiveText") > 0
LIMIT 2
""");
}
@@ -312,7 +312,7 @@ public class SomeArrayEntity
public int Id { get; set; }
[Column(TypeName = "citext")]
- public string CaseInsensitiveText { get; set; }
+ public string CaseInsensitiveText { get; set; } = null!;
}
public class CitextQueryFixture : SharedStoreFixtureBase
diff --git a/test/EFCore.PG.FunctionalTests/Query/Translations/EnumTranslationsNpgsqlTest.cs b/test/EFCore.PG.FunctionalTests/Query/Translations/EnumTranslationsNpgsqlTest.cs
index 807b6e767..a0956799a 100644
--- a/test/EFCore.PG.FunctionalTests/Query/Translations/EnumTranslationsNpgsqlTest.cs
+++ b/test/EFCore.PG.FunctionalTests/Query/Translations/EnumTranslationsNpgsqlTest.cs
@@ -1,7 +1,5 @@
namespace Microsoft.EntityFrameworkCore.Query.Translations;
-#nullable enable
-
public class EnumTranslationsNpgsqlTest : EnumTranslationsTestBase
{
public EnumTranslationsNpgsqlTest(BasicTypesQueryNpgsqlFixture fixture, ITestOutputHelper testOutputHelper)
diff --git a/test/EFCore.PG.FunctionalTests/Query/Translations/EnumTranslationsTest.cs b/test/EFCore.PG.FunctionalTests/Query/Translations/EnumTranslationsTest.cs
index af5555c19..9df854389 100644
--- a/test/EFCore.PG.FunctionalTests/Query/Translations/EnumTranslationsTest.cs
+++ b/test/EFCore.PG.FunctionalTests/Query/Translations/EnumTranslationsTest.cs
@@ -309,7 +309,7 @@ public override DbContextOptionsBuilder AddOptions(DbContextOptionsBuilder build
return optionsBuilder;
}
- private EnumData _expectedData;
+ private EnumData? _expectedData;
protected override Task SeedAsync(EnumContext context)
=> EnumContext.SeedAsync(context);
@@ -321,7 +321,7 @@ public ISetSource GetExpectedData()
=> _expectedData ??= new EnumData();
public IReadOnlyDictionary EntitySorters
- => new Dictionary> { { typeof(SomeEnumEntity), e => ((SomeEnumEntity)e)?.Id } }
+ => new Dictionary> { { typeof(SomeEnumEntity), e => ((SomeEnumEntity)e)?.Id } }
.ToDictionary(e => e.Key, e => (object)e.Value);
public IReadOnlyDictionary EntityAsserters
@@ -331,7 +331,8 @@ public IReadOnlyDictionary EntityAsserters
typeof(SomeEnumEntity), (e, a) =>
{
Assert.Equal(e is null, a is null);
- if (a is not null)
+
+ if (e is not null && a is not null)
{
var ee = (SomeEnumEntity)e;
var aa = (SomeEnumEntity)a;
diff --git a/test/EFCore.PG.FunctionalTests/Query/Translations/LTreeTranslationsTest.cs b/test/EFCore.PG.FunctionalTests/Query/Translations/LTreeTranslationsTest.cs
index f8a41fd21..6645ef768 100644
--- a/test/EFCore.PG.FunctionalTests/Query/Translations/LTreeTranslationsTest.cs
+++ b/test/EFCore.PG.FunctionalTests/Query/Translations/LTreeTranslationsTest.cs
@@ -539,14 +539,14 @@ public class LTreeEntity
public LTree LTree { get; set; }
[Required]
- public LTree[] LTrees { get; set; }
+ public LTree[] LTrees { get; set; } = null!;
[Required]
[Column(TypeName = "ltree")]
- public string LTreeAsString { get; set; }
+ public string LTreeAsString { get; set; } = null!;
[Required]
- public string SomeString { get; set; }
+ public string SomeString { get; set; } = null!;
}
public class LTreeQueryFixture : SharedStoreFixtureBase
diff --git a/test/EFCore.PG.FunctionalTests/Query/Translations/MathTranslationsNpgsqlTest.cs b/test/EFCore.PG.FunctionalTests/Query/Translations/MathTranslationsNpgsqlTest.cs
index 3f7fade26..ddcae5fa7 100644
--- a/test/EFCore.PG.FunctionalTests/Query/Translations/MathTranslationsNpgsqlTest.cs
+++ b/test/EFCore.PG.FunctionalTests/Query/Translations/MathTranslationsNpgsqlTest.cs
@@ -1,7 +1,5 @@
namespace Microsoft.EntityFrameworkCore.Query.Translations;
-#nullable enable
-
public class MathTranslationsNpgsqlTest : MathTranslationsTestBase
{
public MathTranslationsNpgsqlTest(BasicTypesQueryNpgsqlFixture fixture, ITestOutputHelper testOutputHelper)
diff --git a/test/EFCore.PG.FunctionalTests/Query/Translations/MultirangeTranslationsTest.cs b/test/EFCore.PG.FunctionalTests/Query/Translations/MultirangeTranslationsTest.cs
index b6db39283..33ed28771 100644
--- a/test/EFCore.PG.FunctionalTests/Query/Translations/MultirangeTranslationsTest.cs
+++ b/test/EFCore.PG.FunctionalTests/Query/Translations/MultirangeTranslationsTest.cs
@@ -737,13 +737,13 @@ protected override Task SeedAsync(MultirangeContext context)
public class MultirangeTestEntity
{
public int Id { get; set; }
- public NpgsqlRange[] IntMultirange { get; set; }
- public NpgsqlRange[] LongMultirange { get; set; }
- public NpgsqlRange[] DecimalMultirange { get; set; }
- public NpgsqlRange[] DateOnlyDateMultirange { get; set; }
+ public NpgsqlRange[] IntMultirange { get; set; } = null!;
+ public NpgsqlRange[] LongMultirange { get; set; } = null!;
+ public NpgsqlRange[] DecimalMultirange { get; set; } = null!;
+ public NpgsqlRange[] DateOnlyDateMultirange { get; set; } = null!;
[Column(TypeName = "datemultirange")]
- public NpgsqlRange[] DateTimeDateMultirange { get; set; }
+ public NpgsqlRange[] DateTimeDateMultirange { get; set; } = null!;
}
private void AssertSql(params string[] expected)
diff --git a/test/EFCore.PG.FunctionalTests/Query/Translations/NetworkTranslationsNpgsqlTest.cs b/test/EFCore.PG.FunctionalTests/Query/Translations/NetworkTranslationsNpgsqlTest.cs
index 06bbb3373..214c8fa13 100644
--- a/test/EFCore.PG.FunctionalTests/Query/Translations/NetworkTranslationsNpgsqlTest.cs
+++ b/test/EFCore.PG.FunctionalTests/Query/Translations/NetworkTranslationsNpgsqlTest.cs
@@ -65,7 +65,7 @@ public void IPAddress_inet_parse_column()
"""
SELECT count(*)::int
FROM "NetTestEntities" AS n
-WHERE n."Inet" = n."TextInet"::inet OR (n."Inet" IS NULL AND n."TextInet" IS NULL)
+WHERE n."Inet" = n."TextInet"::inet
""");
}
@@ -80,7 +80,7 @@ public void PhysicalAddress_macaddr_parse_column()
"""
SELECT count(*)::int
FROM "NetTestEntities" AS n
-WHERE n."Macaddr" = n."TextMacaddr"::macaddr OR (n."Macaddr" IS NULL AND n."TextMacaddr" IS NULL)
+WHERE n."Macaddr" = n."TextMacaddr"::macaddr
""");
}
@@ -789,7 +789,7 @@ public void BitwiseAnd_IPAddress()
SELECT count(*)::int
FROM "NetTestEntities" AS n
-WHERE n."Inet" = n."Inet" & @p OR n."Inet" IS NULL
+WHERE n."Inet" = n."Inet" & @p
""");
}
@@ -1477,7 +1477,7 @@ public class NetTestEntity
///
/// The network address.
///
- public IPAddress Inet { get; set; }
+ public IPAddress Inet { get; set; } = null!;
///
/// The network address.
@@ -1487,23 +1487,23 @@ public class NetTestEntity
///
/// The MAC address.
///
- public PhysicalAddress Macaddr { get; set; }
+ public PhysicalAddress Macaddr { get; set; } = null!;
///
/// The MAC address.
///
[Column(TypeName = "macaddr8")]
- public PhysicalAddress Macaddr8 { get; set; }
+ public PhysicalAddress Macaddr8 { get; set; } = null!;
///
/// The text form of .
///
- public string TextInet { get; set; }
+ public string TextInet { get; set; } = null!;
///
/// The text form of .
///
- public string TextMacaddr { get; set; }
+ public string TextMacaddr { get; set; } = null!;
}
///
diff --git a/test/EFCore.PG.FunctionalTests/Query/Translations/NodaTime/NodaTimeQueryNpgsqlFixture.cs b/test/EFCore.PG.FunctionalTests/Query/Translations/NodaTime/NodaTimeQueryNpgsqlFixture.cs
index cb4a2edf6..5930b34e4 100644
--- a/test/EFCore.PG.FunctionalTests/Query/Translations/NodaTime/NodaTimeQueryNpgsqlFixture.cs
+++ b/test/EFCore.PG.FunctionalTests/Query/Translations/NodaTime/NodaTimeQueryNpgsqlFixture.cs
@@ -21,7 +21,7 @@ protected override ITestStoreFactory TestStoreFactory
public TestSqlLoggerFactory TestSqlLoggerFactory
=> (TestSqlLoggerFactory)ListLoggerFactory;
- private NodaTimeData _expectedData;
+ private NodaTimeData? _expectedData;
protected override IServiceCollection AddServices(IServiceCollection serviceCollection)
=> base.AddServices(serviceCollection).AddEntityFrameworkNpgsqlNodaTime();
@@ -44,7 +44,7 @@ public ISetSource GetExpectedData()
=> _expectedData ??= new NodaTimeData();
public IReadOnlyDictionary EntitySorters
- => new Dictionary> { { typeof(NodaTimeTypes), e => ((NodaTimeTypes)e)?.Id } }
+ => new Dictionary> { { typeof(NodaTimeTypes), e => ((NodaTimeTypes)e).Id } }
.ToDictionary(e => e.Key, e => (object)e.Value);
public IReadOnlyDictionary EntityAsserters
@@ -54,7 +54,7 @@ public IReadOnlyDictionary EntityAsserters
typeof(NodaTimeTypes), (e, a) =>
{
Assert.Equal(e is null, a is null);
- if (a is not null)
+ if (e is not null && a is not null)
{
var ee = (NodaTimeTypes)e;
var aa = (NodaTimeTypes)a;
diff --git a/test/EFCore.PG.FunctionalTests/Query/Translations/StringTranslationsNpgsqlTest.cs b/test/EFCore.PG.FunctionalTests/Query/Translations/StringTranslationsNpgsqlTest.cs
index 1b8e1d801..77a3ccd11 100644
--- a/test/EFCore.PG.FunctionalTests/Query/Translations/StringTranslationsNpgsqlTest.cs
+++ b/test/EFCore.PG.FunctionalTests/Query/Translations/StringTranslationsNpgsqlTest.cs
@@ -2,8 +2,6 @@
namespace Microsoft.EntityFrameworkCore.Query.Translations;
-#nullable enable
-
public class StringTranslationsNpgsqlTest : StringTranslationsRelationalTestBase
{
public StringTranslationsNpgsqlTest(BasicTypesQueryNpgsqlFixture fixture, ITestOutputHelper testOutputHelper)
diff --git a/test/EFCore.PG.FunctionalTests/Query/Translations/TemporalTranslationsNpgsqlTimestampWithoutTimeZoneTest.cs b/test/EFCore.PG.FunctionalTests/Query/Translations/TemporalTranslationsNpgsqlTimestampWithoutTimeZoneTest.cs
index 1717c417c..3a9d64072 100644
--- a/test/EFCore.PG.FunctionalTests/Query/Translations/TemporalTranslationsNpgsqlTimestampWithoutTimeZoneTest.cs
+++ b/test/EFCore.PG.FunctionalTests/Query/Translations/TemporalTranslationsNpgsqlTimestampWithoutTimeZoneTest.cs
@@ -1,8 +1,6 @@
using Microsoft.EntityFrameworkCore.TestModels.BasicTypesModel;
using Xunit.Sdk;
-#nullable enable
-
namespace Microsoft.EntityFrameworkCore.Query.Translations;
///
diff --git a/test/EFCore.PG.FunctionalTests/Query/Translations/TimestampTranslationsTest.cs b/test/EFCore.PG.FunctionalTests/Query/Translations/TimestampTranslationsTest.cs
index 83392d987..bd62f8ec6 100644
--- a/test/EFCore.PG.FunctionalTests/Query/Translations/TimestampTranslationsTest.cs
+++ b/test/EFCore.PG.FunctionalTests/Query/Translations/TimestampTranslationsTest.cs
@@ -897,12 +897,12 @@ public class Entity
public DateTimeOffset TimestampDateTimeOffset { get; set; }
- public DateTime[] TimestamptzDateTimeArray { get; set; }
+ public DateTime[]? TimestamptzDateTimeArray { get; set; }
[Column(TypeName = "timestamp without time zone[]")]
- public DateTime[] TimestampDateTimeArray { get; set; }
+ public DateTime[]? TimestampDateTimeArray { get; set; }
- public DateTimeOffset[] TimestampDateTimeOffsetArray { get; set; }
+ public DateTimeOffset[]? TimestampDateTimeOffsetArray { get; set; }
public NpgsqlRange TimestamptzDateTimeRange { get; set; }
@@ -924,7 +924,7 @@ protected override ITestStoreFactory TestStoreFactory
public TestSqlLoggerFactory TestSqlLoggerFactory
=> (TestSqlLoggerFactory)ListLoggerFactory;
- private TimestampData _expectedData;
+ private TimestampData? _expectedData;
protected override Task SeedAsync(TimestampQueryContext context)
=> TimestampQueryContext.SeedAsync(context);
@@ -936,7 +936,7 @@ public ISetSource GetExpectedData()
=> _expectedData ??= new TimestampData();
public IReadOnlyDictionary EntitySorters
- => new Dictionary> { { typeof(Entity), e => ((Entity)e)?.Id } }
+ => new Dictionary> { { typeof(Entity), e => ((Entity)e)?.Id } }
.ToDictionary(e => e.Key, e => (object)e.Value);
public IReadOnlyDictionary EntityAsserters
@@ -948,7 +948,7 @@ public IReadOnlyDictionary EntityAsserters
Assert.Equal(e is null, a is null);
if (a is not null)
{
- var ee = (Entity)e;
+ var ee = (Entity)e!;
var aa = (Entity)a;
Assert.Equal(ee.Id, aa.Id);
diff --git a/test/EFCore.PG.FunctionalTests/Query/Translations/TrigramsTranslationsTest.cs b/test/EFCore.PG.FunctionalTests/Query/Translations/TrigramsTranslationsTest.cs
index 64d2591d5..ff527c265 100644
--- a/test/EFCore.PG.FunctionalTests/Query/Translations/TrigramsTranslationsTest.cs
+++ b/test/EFCore.PG.FunctionalTests/Query/Translations/TrigramsTranslationsTest.cs
@@ -192,7 +192,7 @@ public void Concatenation_operator_precedence()
"""
SELECT t."Id", t."Text"
FROM "TrigramsTestEntities" AS t
-WHERE (COALESCE(t."Text", '') || ' ' || COALESCE(t."Text", '')) % 'query'
+WHERE (t."Text" || ' ' || t."Text") % 'query'
""");
}
@@ -247,7 +247,7 @@ public class TrigramsTestEntity
///
/// Some text.
///
- public string Text { get; set; }
+ public string Text { get; set; } = null!;
}
///
diff --git a/test/EFCore.PG.FunctionalTests/Query/UdfDbFunctionNpgsqlTests.cs b/test/EFCore.PG.FunctionalTests/Query/UdfDbFunctionNpgsqlTests.cs
index a1652ec85..38f70731e 100644
--- a/test/EFCore.PG.FunctionalTests/Query/UdfDbFunctionNpgsqlTests.cs
+++ b/test/EFCore.PG.FunctionalTests/Query/UdfDbFunctionNpgsqlTests.cs
@@ -2,6 +2,8 @@
namespace Npgsql.EntityFrameworkCore.PostgreSQL.Query;
+#nullable disable
+
public class UdfDbFunctionNpgsqlTests : UdfDbFunctionTestBase
{
// ReSharper disable once UnusedParameter.Local
diff --git a/test/EFCore.PG.FunctionalTests/Scaffolding/NpgsqlDatabaseModelFactoryTest.cs b/test/EFCore.PG.FunctionalTests/Scaffolding/NpgsqlDatabaseModelFactoryTest.cs
index 6357a3676..79b6062cf 100644
--- a/test/EFCore.PG.FunctionalTests/Scaffolding/NpgsqlDatabaseModelFactoryTest.cs
+++ b/test/EFCore.PG.FunctionalTests/Scaffolding/NpgsqlDatabaseModelFactoryTest.cs
@@ -555,9 +555,9 @@ public void Create_primary_key()
[],
dbModel =>
{
- var pk = dbModel.Tables.Single().PrimaryKey;
+ var pk = dbModel.Tables.Single().PrimaryKey!;
- Assert.Equal("public", pk.Table.Schema);
+ Assert.Equal("public", pk.Table!.Schema);
Assert.Equal("PrimaryKeyTable", pk.Table.Name);
Assert.StartsWith("PrimaryKeyTable_pkey", pk.Name);
Assert.Equal(["Id"], pk.Columns.Select(ic => ic.Name).ToList());
@@ -629,7 +629,7 @@ public void Create_indexes()
Assert.All(
table.Indexes, c =>
{
- Assert.Equal("public", c.Table.Schema);
+ Assert.Equal("public", c.Table!.Schema);
Assert.Equal("IndexTable", c.Table.Name);
});
@@ -1133,9 +1133,9 @@ PRIMARY KEY ("Id2", "Id1")
[],
dbModel =>
{
- var pk = dbModel.Tables.Single().PrimaryKey;
+ var pk = dbModel.Tables.Single().PrimaryKey!;
- Assert.Equal("public", pk.Table.Schema);
+ Assert.Equal("public", pk.Table!.Schema);
Assert.Equal("CompositePrimaryKeyTable", pk.Table.Name);
Assert.Equal(["Id2", "Id1"], pk.Columns.Select(ic => ic.Name).ToList());
},
@@ -1157,9 +1157,9 @@ public void Set_primary_key_name_from_index()
[],
dbModel =>
{
- var pk = dbModel.Tables.Single().PrimaryKey;
+ var pk = dbModel.Tables.Single().PrimaryKey!;
- Assert.Equal("public", pk.Table.Schema);
+ Assert.Equal("public", pk.Table!.Schema);
Assert.Equal("PrimaryKeyName", pk.Table.Name);
Assert.StartsWith("MyPK", pk.Name);
Assert.Equal(["Id2"], pk.Columns.Select(ic => ic.Name).ToList());
@@ -1248,7 +1248,7 @@ public void Create_composite_index()
var index = Assert.Single(dbModel.Tables.Single().Indexes);
// ReSharper disable once PossibleNullReferenceException
- Assert.Equal("public", index.Table.Schema);
+ Assert.Equal("public", index.Table!.Schema);
Assert.Equal("CompositeIndexTable", index.Table.Name);
Assert.Equal("IX_COMPOSITE", index.Name);
Assert.Equal(["Id2", "Id1"], index.Columns.Select(ic => ic.Name).ToList());
@@ -1275,7 +1275,7 @@ public void Set_unique_true_for_unique_index()
var index = Assert.Single(dbModel.Tables.Single().Indexes);
// ReSharper disable once PossibleNullReferenceException
- Assert.Equal("public", index.Table.Schema);
+ Assert.Equal("public", index.Table!.Schema);
Assert.Equal("UniqueIndexTable", index.Table.Name);
Assert.Equal("IX_UNIQUE", index.Name);
Assert.True(index.IsUnique);
@@ -1304,7 +1304,7 @@ public void Set_filter_for_filtered_index()
var index = Assert.Single(dbModel.Tables.Single().Indexes);
// ReSharper disable once PossibleNullReferenceException
- Assert.Equal("public", index.Table.Schema);
+ Assert.Equal("public", index.Table!.Schema);
Assert.Equal("FilteredIndexTable", index.Table.Name);
Assert.Equal("IX_UNIQUE", index.Name);
Assert.Equal("""("Id2" > 10)""", index.Filter);
@@ -1644,7 +1644,7 @@ public void SequenceSerial()
Assert.Null(column.DefaultValueSql);
Assert.Equal(
NpgsqlValueGenerationStrategy.SerialColumn,
- (NpgsqlValueGenerationStrategy)column[NpgsqlAnnotationNames.ValueGenerationStrategy]);
+ (NpgsqlValueGenerationStrategy?)column[NpgsqlAnnotationNames.ValueGenerationStrategy]);
}
},
"""
@@ -1698,21 +1698,21 @@ b int GENERATED BY DEFAULT AS IDENTITY
Assert.Null(idIdentityAlways.DefaultValueSql);
Assert.Equal(
NpgsqlValueGenerationStrategy.IdentityAlwaysColumn,
- (NpgsqlValueGenerationStrategy)idIdentityAlways[NpgsqlAnnotationNames.ValueGenerationStrategy]);
+ (NpgsqlValueGenerationStrategy?)idIdentityAlways[NpgsqlAnnotationNames.ValueGenerationStrategy]);
var identityAlways = dbModel.Tables.Single().Columns.Single(c => c.Name == "a");
Assert.Equal(ValueGenerated.OnAdd, identityAlways.ValueGenerated);
Assert.Null(identityAlways.DefaultValueSql);
Assert.Equal(
NpgsqlValueGenerationStrategy.IdentityAlwaysColumn,
- (NpgsqlValueGenerationStrategy)identityAlways[NpgsqlAnnotationNames.ValueGenerationStrategy]);
+ (NpgsqlValueGenerationStrategy?)identityAlways[NpgsqlAnnotationNames.ValueGenerationStrategy]);
var identityByDefault = dbModel.Tables.Single().Columns.Single(c => c.Name == "b");
Assert.Equal(ValueGenerated.OnAdd, identityByDefault.ValueGenerated);
Assert.Null(identityByDefault.DefaultValueSql);
Assert.Equal(
NpgsqlValueGenerationStrategy.IdentityByDefaultColumn,
- (NpgsqlValueGenerationStrategy)identityByDefault[NpgsqlAnnotationNames.ValueGenerationStrategy]);
+ (NpgsqlValueGenerationStrategy?)identityByDefault[NpgsqlAnnotationNames.ValueGenerationStrategy]);
},
"DROP TABLE identity");
@@ -1735,7 +1735,7 @@ smallint_without_options smallint GENERATED BY DEFAULT AS IDENTITY
var withOptions = dbModel.Tables.Single().Columns.Single(c => c.Name == "with_options");
Assert.Equal(
NpgsqlValueGenerationStrategy.IdentityByDefaultColumn,
- (NpgsqlValueGenerationStrategy)withOptions[NpgsqlAnnotationNames.ValueGenerationStrategy]);
+ (NpgsqlValueGenerationStrategy?)withOptions[NpgsqlAnnotationNames.ValueGenerationStrategy]);
Assert.Equal(
new IdentitySequenceOptionsData
{
@@ -1751,21 +1751,21 @@ smallint_without_options smallint GENERATED BY DEFAULT AS IDENTITY
Assert.Equal("integer", withOptions.StoreType);
Assert.Equal(
NpgsqlValueGenerationStrategy.IdentityByDefaultColumn,
- (NpgsqlValueGenerationStrategy)withoutOptions[NpgsqlAnnotationNames.ValueGenerationStrategy]);
+ (NpgsqlValueGenerationStrategy?)withoutOptions[NpgsqlAnnotationNames.ValueGenerationStrategy]);
Assert.Null(withoutOptions[NpgsqlAnnotationNames.IdentityOptions]);
var bigintWithoutOptions = dbModel.Tables.Single().Columns.Single(c => c.Name == "bigint_without_options");
Assert.Equal("bigint", bigintWithoutOptions.StoreType);
Assert.Equal(
NpgsqlValueGenerationStrategy.IdentityByDefaultColumn,
- (NpgsqlValueGenerationStrategy)bigintWithoutOptions[NpgsqlAnnotationNames.ValueGenerationStrategy]);
+ (NpgsqlValueGenerationStrategy?)bigintWithoutOptions[NpgsqlAnnotationNames.ValueGenerationStrategy]);
Assert.Null(bigintWithoutOptions[NpgsqlAnnotationNames.IdentityOptions]);
var smallintWithoutOptions = dbModel.Tables.Single().Columns.Single(c => c.Name == "smallint_without_options");
Assert.Equal("smallint", smallintWithoutOptions.StoreType);
Assert.Equal(
NpgsqlValueGenerationStrategy.IdentityByDefaultColumn,
- (NpgsqlValueGenerationStrategy)smallintWithoutOptions[NpgsqlAnnotationNames.ValueGenerationStrategy]);
+ (NpgsqlValueGenerationStrategy?)smallintWithoutOptions[NpgsqlAnnotationNames.ValueGenerationStrategy]);
Assert.Null(smallintWithoutOptions[NpgsqlAnnotationNames.IdentityOptions]);
},
"DROP TABLE identity");
@@ -1816,7 +1816,7 @@ public void Index_method()
Assert.Equal(2, table.Indexes.Count);
var methodIndex = table.Indexes.Single(i => i.Name == "ix_a");
- Assert.Equal("hash", methodIndex.FindAnnotation(NpgsqlAnnotationNames.IndexMethod).Value);
+ Assert.Equal("hash", methodIndex[NpgsqlAnnotationNames.IndexMethod]);
// It's cleaner to always output the index method on the database model,
// even when it's btree (the default);
@@ -1846,7 +1846,7 @@ public void Index_operators()
var table = dbModel.Tables.Single();
var indexWith = table.Indexes.Single(i => i.Name == "ix_with");
- Assert.Equal(new[] { null, "varchar_pattern_ops" }, indexWith.FindAnnotation(NpgsqlAnnotationNames.IndexOperators).Value);
+ Assert.Equal(new[] { null, "varchar_pattern_ops" }, indexWith[NpgsqlAnnotationNames.IndexOperators]);
var indexWithout = table.Indexes.Single(i => i.Name == "ix_without");
Assert.Null(indexWithout.FindAnnotation(NpgsqlAnnotationNames.IndexOperators));
@@ -1870,7 +1870,7 @@ public void Index_collation()
var table = dbModel.Tables.Single();
var indexWith = table.Indexes.Single(i => i.Name == "ix_with");
- Assert.Equal(new[] { null, "POSIX" }, indexWith.FindAnnotation(RelationalAnnotationNames.Collation).Value);
+ Assert.Equal(new[] { null, "POSIX" }, indexWith[RelationalAnnotationNames.Collation]);
var indexWithout = table.Indexes.Single(i => i.Name == "ix_without");
Assert.Null(indexWithout.FindAnnotation(RelationalAnnotationNames.Collation));
@@ -1930,7 +1930,7 @@ public void Index_null_sort_order()
var indexWith = table.Indexes.Single(i => i.Name == "ix_with");
Assert.Equal(
new[] { NullSortOrder.NullsFirst, NullSortOrder.NullsLast },
- indexWith.FindAnnotation(NpgsqlAnnotationNames.IndexNullSortOrder).Value);
+ indexWith[NpgsqlAnnotationNames.IndexNullSortOrder]);
var indexWithout = table.Indexes.Single(i => i.Name == "ix_without");
Assert.Null(indexWithout.FindAnnotation(NpgsqlAnnotationNames.IndexNullSortOrder));
@@ -2194,7 +2194,7 @@ line line
Assert.Equal(column.Name, column.StoreType);
Assert.Equal(
column.StoreType,
- typeMappingSource.FindMapping(column.StoreType).StoreType
+ typeMappingSource.FindMapping(column.StoreType!)!.StoreType
);
}
},
@@ -2220,7 +2220,7 @@ private void Test(
IEnumerable tables,
IEnumerable schemas,
Action asserter,
- string cleanupSql)
+ string? cleanupSql)
{
Fixture.TestStore.ExecuteNonQuery(createSql);
diff --git a/test/EFCore.PG.FunctionalTests/SequenceEndToEndTest.cs b/test/EFCore.PG.FunctionalTests/SequenceEndToEndTest.cs
index 715fa78fa..bc6147a55 100644
--- a/test/EFCore.PG.FunctionalTests/SequenceEndToEndTest.cs
+++ b/test/EFCore.PG.FunctionalTests/SequenceEndToEndTest.cs
@@ -2,6 +2,8 @@
namespace Npgsql.EntityFrameworkCore.PostgreSQL;
+#nullable disable
+
public class SequenceEndToEndTest : IAsyncLifetime
{
[ConditionalFact]
@@ -386,10 +388,10 @@ protected override void OnModelCreating(ModelBuilder modelBuilder)
private class Unicon
{
public int? Identifier { get; set; }
- public string Name { get; set; }
+ public string Name { get; set; } = null!;
}
- protected NpgsqlTestStore TestStore { get; private set; }
+ protected NpgsqlTestStore TestStore { get; private set; } = null!;
public async Task InitializeAsync()
=> TestStore = await NpgsqlTestStore.CreateInitializedAsync("SequenceEndToEndTest");
diff --git a/test/EFCore.PG.FunctionalTests/SystemColumnTest.cs b/test/EFCore.PG.FunctionalTests/SystemColumnTest.cs
index cd7150436..d8e949688 100644
--- a/test/EFCore.PG.FunctionalTests/SystemColumnTest.cs
+++ b/test/EFCore.PG.FunctionalTests/SystemColumnTest.cs
@@ -49,7 +49,7 @@ public class SomeEntity
// ReSharper disable UnusedMember.Global
// ReSharper disable UnusedAutoPropertyAccessor.Global
public int Id { get; set; }
- public string Name { get; set; }
+ public string Name { get; set; } = null!;
public uint Version { get; set; }
// ReSharper restore UnusedMember.Global
diff --git a/test/EFCore.PG.FunctionalTests/TestModels/Array/ArrayContainerEntity.cs b/test/EFCore.PG.FunctionalTests/TestModels/Array/ArrayContainerEntity.cs
index 53049b0c6..7d65701f1 100644
--- a/test/EFCore.PG.FunctionalTests/TestModels/Array/ArrayContainerEntity.cs
+++ b/test/EFCore.PG.FunctionalTests/TestModels/Array/ArrayContainerEntity.cs
@@ -1,5 +1,3 @@
-#nullable enable
-
namespace Npgsql.EntityFrameworkCore.PostgreSQL.TestModels.Array;
public class ArrayContainerEntity
diff --git a/test/EFCore.PG.FunctionalTests/TestModels/Array/ArrayEntity.cs b/test/EFCore.PG.FunctionalTests/TestModels/Array/ArrayEntity.cs
index c7dde4960..1a79914d8 100644
--- a/test/EFCore.PG.FunctionalTests/TestModels/Array/ArrayEntity.cs
+++ b/test/EFCore.PG.FunctionalTests/TestModels/Array/ArrayEntity.cs
@@ -1,5 +1,3 @@
-#nullable enable
-
namespace Npgsql.EntityFrameworkCore.PostgreSQL.TestModels.Array;
public class ArrayEntity
diff --git a/test/EFCore.PG.FunctionalTests/TestModels/Array/ArrayQueryContext.cs b/test/EFCore.PG.FunctionalTests/TestModels/Array/ArrayQueryContext.cs
index 389023fd6..68b02923d 100644
--- a/test/EFCore.PG.FunctionalTests/TestModels/Array/ArrayQueryContext.cs
+++ b/test/EFCore.PG.FunctionalTests/TestModels/Array/ArrayQueryContext.cs
@@ -32,7 +32,7 @@ protected override void OnModelCreating(ModelBuilder modelBuilder)
v => string.Join(",", v),
v => v.Split(',', StringSplitOptions.None).ToList(),
new ValueComparer>(
- (c1, c2) => c1.SequenceEqual(c2),
+ (c1, c2) => c1 == null && c2 == null || (c1 != null && c2 != null && c1.SequenceEqual(c2)),
c => c.Aggregate(0, (a, v) => HashCode.Combine(a, v.GetHashCode())),
c => c.ToList()));
@@ -41,7 +41,7 @@ protected override void OnModelCreating(ModelBuilder modelBuilder)
v => string.Join(",", v),
v => v.Split(',', StringSplitOptions.None).ToArray(),
new ValueComparer(
- (c1, c2) => c1.SequenceEqual(c2),
+ (c1, c2) => c1 == null && c2 == null || (c1 != null && c2 != null && c1.SequenceEqual(c2)),
c => c.Aggregate(0, (a, v) => HashCode.Combine(a, v.GetHashCode())),
c => c.ToArray()));
diff --git a/test/EFCore.PG.FunctionalTests/TestModels/NodaTime/NodaTimeTypes.cs b/test/EFCore.PG.FunctionalTests/TestModels/NodaTime/NodaTimeTypes.cs
index 2a1087d8a..fa1faddc4 100644
--- a/test/EFCore.PG.FunctionalTests/TestModels/NodaTime/NodaTimeTypes.cs
+++ b/test/EFCore.PG.FunctionalTests/TestModels/NodaTime/NodaTimeTypes.cs
@@ -13,15 +13,15 @@ public class NodaTimeTypes
public LocalDate LocalDate2 { get; set; }
public LocalTime LocalTime { get; set; }
public OffsetTime OffsetTime { get; set; }
- public Period Period { get; set; }
+ public Period Period { get; set; } = null!;
public Duration Duration { get; set; }
- public DateInterval DateInterval { get; set; }
+ public DateInterval DateInterval { get; set; } = null!;
public NpgsqlRange LocalDateRange { get; set; }
public Interval Interval { get; set; }
public NpgsqlRange InstantRange { get; set; }
public long Long { get; set; }
- public string TimeZoneId { get; set; }
+ public string TimeZoneId { get; set; } = null!;
// ReSharper restore UnusedAutoPropertyAccessor.Global
}
diff --git a/test/EFCore.PG.FunctionalTests/TestUtilities/NpgsqlTestStore.cs b/test/EFCore.PG.FunctionalTests/TestUtilities/NpgsqlTestStore.cs
index 8b4ba0381..2831aa598 100644
--- a/test/EFCore.PG.FunctionalTests/TestUtilities/NpgsqlTestStore.cs
+++ b/test/EFCore.PG.FunctionalTests/TestUtilities/NpgsqlTestStore.cs
@@ -5,8 +5,6 @@
namespace Npgsql.EntityFrameworkCore.PostgreSQL.TestUtilities;
-#nullable enable
-
public class NpgsqlTestStore : RelationalTestStore
{
private readonly string? _scriptPath;
diff --git a/test/EFCore.PG.FunctionalTests/TestUtilities/NpgsqlTestStoreFactory.cs b/test/EFCore.PG.FunctionalTests/TestUtilities/NpgsqlTestStoreFactory.cs
index 06de22f29..3b3c5667b 100644
--- a/test/EFCore.PG.FunctionalTests/TestUtilities/NpgsqlTestStoreFactory.cs
+++ b/test/EFCore.PG.FunctionalTests/TestUtilities/NpgsqlTestStoreFactory.cs
@@ -1,7 +1,5 @@
namespace Npgsql.EntityFrameworkCore.PostgreSQL.TestUtilities;
-#nullable enable
-
public class NpgsqlTestStoreFactory(
string? scriptPath = null,
string? additionalSql = null,
diff --git a/test/EFCore.PG.FunctionalTests/TestUtilities/TestEnvironment.cs b/test/EFCore.PG.FunctionalTests/TestUtilities/TestEnvironment.cs
index 43ac5e3fe..f11ffb509 100644
--- a/test/EFCore.PG.FunctionalTests/TestUtilities/TestEnvironment.cs
+++ b/test/EFCore.PG.FunctionalTests/TestUtilities/TestEnvironment.cs
@@ -26,7 +26,7 @@ static TestEnvironment()
public static string DefaultConnection
=> Config["DefaultConnection"] ?? DefaultConnectionString;
- private static Version _postgresVersion;
+ private static Version? _postgresVersion;
public static Version PostgresVersion
{
@@ -59,7 +59,7 @@ public static bool IsPostgisAvailable
using var cmd = conn.CreateCommand();
cmd.CommandText = "SELECT EXISTS (SELECT 1 FROM pg_available_extensions WHERE \"name\" = 'postgis' LIMIT 1)";
- _isPostgisAvailable = (bool)cmd.ExecuteScalar();
+ _isPostgisAvailable = (bool)cmd.ExecuteScalar()!;
return _isPostgisAvailable.Value;
}
}
diff --git a/test/EFCore.PG.FunctionalTests/TestUtilities/TestNpgsqlConnection.cs b/test/EFCore.PG.FunctionalTests/TestUtilities/TestNpgsqlConnection.cs
index 15ef578c7..737b8bd33 100644
--- a/test/EFCore.PG.FunctionalTests/TestUtilities/TestNpgsqlConnection.cs
+++ b/test/EFCore.PG.FunctionalTests/TestUtilities/TestNpgsqlConnection.cs
@@ -4,7 +4,7 @@
namespace Npgsql.EntityFrameworkCore.PostgreSQL.TestUtilities;
-public class TestNpgsqlConnection(RelationalConnectionDependencies dependencies, DbDataSource dataSource = null)
+public class TestNpgsqlConnection(RelationalConnectionDependencies dependencies, DbDataSource? dataSource = null)
: NpgsqlRelationalConnection(dependencies, dataSource)
{
public string ErrorCode { get; set; } = "XX000";
diff --git a/test/EFCore.PG.FunctionalTests/TestUtilities/TestNpgsqlRetryingExecutionStrategy.cs b/test/EFCore.PG.FunctionalTests/TestUtilities/TestNpgsqlRetryingExecutionStrategy.cs
index c443ccdc8..f1448bfd1 100644
--- a/test/EFCore.PG.FunctionalTests/TestUtilities/TestNpgsqlRetryingExecutionStrategy.cs
+++ b/test/EFCore.PG.FunctionalTests/TestUtilities/TestNpgsqlRetryingExecutionStrategy.cs
@@ -32,7 +32,7 @@ public TestNpgsqlRetryingExecutionStrategy(ExecutionStrategyDependencies depende
{
}
- protected override bool ShouldRetryOn(Exception exception)
+ protected override bool ShouldRetryOn(Exception? exception)
{
if (base.ShouldRetryOn(exception))
{
diff --git a/test/EFCore.PG.FunctionalTests/TestUtilities/TestRelationalCommandBuilderFactory.cs b/test/EFCore.PG.FunctionalTests/TestUtilities/TestRelationalCommandBuilderFactory.cs
index 38d349250..16a678ae1 100644
--- a/test/EFCore.PG.FunctionalTests/TestUtilities/TestRelationalCommandBuilderFactory.cs
+++ b/test/EFCore.PG.FunctionalTests/TestUtilities/TestRelationalCommandBuilderFactory.cs
@@ -129,7 +129,7 @@ public Task ExecuteNonQueryAsync(
return result;
}
- public object ExecuteScalar(RelationalCommandParameterObject parameterObject)
+ public object? ExecuteScalar(RelationalCommandParameterObject parameterObject)
{
var connection = parameterObject.Connection;
var errorNumber = PreExecution(connection);
@@ -144,7 +144,7 @@ public object ExecuteScalar(RelationalCommandParameterObject parameterObject)
return result;
}
- public async Task