From d218ae0f742da77dada5eae962bc351d7e3f3008 Mon Sep 17 00:00:00 2001
From: Martijn Bodeman <11424653+skwasjer@users.noreply.github.com>
Date: Sun, 6 Oct 2024 06:09:57 +0200
Subject: [PATCH] refactor: replace .NET Core 3.1 with .NET 7 to test .NET
Standard 2.1. (#123)
---
test/Directory.Build.targets | 3 +++
test/MockHttp.Json.Tests/MockHttp.Json.Tests.csproj | 7 +++++--
...d.txt => .NET_Standard_2.1_via_.NET_7.0.verified.txt} | 0
test/MockHttp.Testing/MockHttp.Testing.csproj | 8 +++++---
test/MockHttp.Testing/Specs/PublicApiSpec.cs | 2 +-
test/MockHttp.Tests/Internal/Http/EmptyContentTests.cs | 3 +--
.../Internal/Http/HttpHeadersCollectionTests.cs | 9 +++++++++
test/MockHttp.Tests/MockHttp.Tests.csproj | 5 ++++-
...d.txt => .NET_Standard_2.1_via_.NET_7.0.verified.txt} | 0
9 files changed, 28 insertions(+), 9 deletions(-)
rename test/MockHttp.Json.Tests/PublicApi/{.NET_Standard_2.1_via_.NET_Core_3.1.verified.txt => .NET_Standard_2.1_via_.NET_7.0.verified.txt} (100%)
rename test/MockHttp.Tests/PublicApi/{.NET_Standard_2.1_via_.NET_Core_3.1.verified.txt => .NET_Standard_2.1_via_.NET_7.0.verified.txt} (100%)
diff --git a/test/Directory.Build.targets b/test/Directory.Build.targets
index e50c4afd..fb66ddc0 100644
--- a/test/Directory.Build.targets
+++ b/test/Directory.Build.targets
@@ -6,6 +6,9 @@
$(NoWarn);NU1902;NU1903;xUnit1042
17.11.1
true
+
+ true
+ $(DefineConstants);TEST_NETSTANDARD2_1
diff --git a/test/MockHttp.Json.Tests/MockHttp.Json.Tests.csproj b/test/MockHttp.Json.Tests/MockHttp.Json.Tests.csproj
index e61161eb..fb32704b 100644
--- a/test/MockHttp.Json.Tests/MockHttp.Json.Tests.csproj
+++ b/test/MockHttp.Json.Tests/MockHttp.Json.Tests.csproj
@@ -1,7 +1,7 @@
- net8.0;net6.0;net5.0;netcoreapp3.1;netcoreapp2.1;net48;net472;net462
+ net8.0;net7.0;net6.0;net5.0;netcoreapp2.1;net48;net472;net462
true
@@ -14,7 +14,10 @@
-
+
+
+
+
\ No newline at end of file
diff --git a/test/MockHttp.Json.Tests/PublicApi/.NET_Standard_2.1_via_.NET_Core_3.1.verified.txt b/test/MockHttp.Json.Tests/PublicApi/.NET_Standard_2.1_via_.NET_7.0.verified.txt
similarity index 100%
rename from test/MockHttp.Json.Tests/PublicApi/.NET_Standard_2.1_via_.NET_Core_3.1.verified.txt
rename to test/MockHttp.Json.Tests/PublicApi/.NET_Standard_2.1_via_.NET_7.0.verified.txt
diff --git a/test/MockHttp.Testing/MockHttp.Testing.csproj b/test/MockHttp.Testing/MockHttp.Testing.csproj
index 70d7a1ae..f3fb2b26 100644
--- a/test/MockHttp.Testing/MockHttp.Testing.csproj
+++ b/test/MockHttp.Testing/MockHttp.Testing.csproj
@@ -1,14 +1,14 @@
- net8.0;net6.0;net5.0;netcoreapp3.1;netcoreapp2.1;net48;net472;net462
+ net8.0;net7.0;net6.0;net5.0;netcoreapp2.1;net48;net472;net462
false
MockHttp
26.6.0
- 20.8.2
+ 20.8.2
18.1.0
true
$(DefineConstants);VERIFY_PUBLIC_API
@@ -25,7 +25,9 @@
-
+
+
+
\ No newline at end of file
diff --git a/test/MockHttp.Testing/Specs/PublicApiSpec.cs b/test/MockHttp.Testing/Specs/PublicApiSpec.cs
index f6d091c6..39a45c36 100644
--- a/test/MockHttp.Testing/Specs/PublicApiSpec.cs
+++ b/test/MockHttp.Testing/Specs/PublicApiSpec.cs
@@ -45,7 +45,7 @@ public Task Api_has_not_changed()
string sutTargetFramework = GetTargetFramework(sut);
string testTargetFramework = GetTargetFramework(GetType().Assembly);
settings.UseFileName(
- sutTargetFramework == testTargetFramework
+ sutTargetFramework == testTargetFramework || string.IsNullOrEmpty(testTargetFramework)
? sutTargetFramework
: $"{sutTargetFramework}_via_{testTargetFramework}"
);
diff --git a/test/MockHttp.Tests/Internal/Http/EmptyContentTests.cs b/test/MockHttp.Tests/Internal/Http/EmptyContentTests.cs
index e15b991a..5e2ea242 100644
--- a/test/MockHttp.Tests/Internal/Http/EmptyContentTests.cs
+++ b/test/MockHttp.Tests/Internal/Http/EmptyContentTests.cs
@@ -28,8 +28,7 @@ public async Task When_reading_stream_async_it_should_return_empty()
stream.Length.Should().Be(0);
}
-#if NET6_0_OR_GREATER
-
+#if NET6_0_OR_GREATER && !TEST_NETSTANDARD2_1
[Fact]
public async Task When_reading_stream_sync_it_should_return_empty()
{
diff --git a/test/MockHttp.Tests/Internal/Http/HttpHeadersCollectionTests.cs b/test/MockHttp.Tests/Internal/Http/HttpHeadersCollectionTests.cs
index 5803d254..775e6d74 100644
--- a/test/MockHttp.Tests/Internal/Http/HttpHeadersCollectionTests.cs
+++ b/test/MockHttp.Tests/Internal/Http/HttpHeadersCollectionTests.cs
@@ -55,6 +55,14 @@ public void Given_single_header_string_when_parsing_should_return_key_with_one_o
[InlineData("\tleading-whitespace-not-allowed:value", "The header name '\tleading-whitespace-not-allowed' has an invalid format.")]
[InlineData("trailing-whitespace-not-allowed :value", "The header name 'trailing-whitespace-not-allowed ' has an invalid format.")]
[InlineData("trailing-whitespace-not-allowed\t:value", "The header name 'trailing-whitespace-not-allowed\t' has an invalid format.")]
+#else
+#if TEST_NETSTANDARD2_1
+ [InlineData(":value", "The value cannot be null or empty.*")]
+ [InlineData(" :value", "The header name ' ' has an invalid format.")]
+ [InlineData(" leading-whitespace-not-allowed:value", "The header name ' leading-whitespace-not-allowed' has an invalid format.")]
+ [InlineData("\tleading-whitespace-not-allowed:value", "The header name '\tleading-whitespace-not-allowed' has an invalid format.")]
+ [InlineData("trailing-whitespace-not-allowed :value", "The header name 'trailing-whitespace-not-allowed ' has an invalid format.")]
+ [InlineData("trailing-whitespace-not-allowed\t:value", "The header name 'trailing-whitespace-not-allowed\t' has an invalid format.")]
#else
[InlineData(":value", "The value cannot be null or empty.*")]
[InlineData(" :value", "The header name format is invalid.")]
@@ -62,6 +70,7 @@ public void Given_single_header_string_when_parsing_should_return_key_with_one_o
[InlineData("\tleading-whitespace-not-allowed:value", "The header name format is invalid.")]
[InlineData("trailing-whitespace-not-allowed :value", "The header name format is invalid.")]
[InlineData("trailing-whitespace-not-allowed\t:value", "The header name format is invalid.")]
+#endif
#endif
public void Given_single_invalid_header_string_with_when_parsing_should_throw(string invalidHeaderString, string exceptionMessage)
{
diff --git a/test/MockHttp.Tests/MockHttp.Tests.csproj b/test/MockHttp.Tests/MockHttp.Tests.csproj
index 12655723..b7c51a88 100644
--- a/test/MockHttp.Tests/MockHttp.Tests.csproj
+++ b/test/MockHttp.Tests/MockHttp.Tests.csproj
@@ -1,7 +1,7 @@
- net8.0;net6.0;net5.0;netcoreapp3.1;netcoreapp2.1;net48;net472;net462
+ net8.0;net7.0;net6.0;net5.0;netcoreapp2.1;net48;net472;net462
true
@@ -14,6 +14,9 @@
+
+
+
diff --git a/test/MockHttp.Tests/PublicApi/.NET_Standard_2.1_via_.NET_Core_3.1.verified.txt b/test/MockHttp.Tests/PublicApi/.NET_Standard_2.1_via_.NET_7.0.verified.txt
similarity index 100%
rename from test/MockHttp.Tests/PublicApi/.NET_Standard_2.1_via_.NET_Core_3.1.verified.txt
rename to test/MockHttp.Tests/PublicApi/.NET_Standard_2.1_via_.NET_7.0.verified.txt