From 4605dd3388f5c7ba39fb8163a23c6acb7df460cd Mon Sep 17 00:00:00 2001 From: Gregorius Soedharmo Date: Thu, 25 Mar 2021 01:22:07 +0700 Subject: [PATCH 1/4] Update the cross framework spec to include complex POCO object, Type serialization, and support for netcoreapp3.1 and net5.0 --- .../CrossFrameworkSerializationTests.cs | 31 +++++++++++-- .../Generator/CrossFrameworkClass.cs | 43 ++++++++++++++++++ .../Generator/CrossFrameworkInitializer.cs | 11 +++++ src/Hyperion.Tests/Generator/Program.cs | 9 +++- src/Hyperion.Tests/Hyperion.Tests.csproj | 2 +- .../mixed_test_file_.netcoreappversionv2.0.tf | Bin 0 -> 743 bytes .../mixed_test_file_.netcoreappversionv2.1.tf | Bin 0 -> 743 bytes .../mixed_test_file_.netcoreappversionv2.2.tf | Bin 0 -> 743 bytes .../mixed_test_file_.netcoreappversionv3.0.tf | Bin 0 -> 743 bytes .../mixed_test_file_.netcoreappversionv3.1.tf | Bin 0 -> 743 bytes .../mixed_test_file_.netcoreappversionv5.0.tf | Bin 0 -> 743 bytes ...ed_test_file_.netframeworkversionv4.6.1.tf | Bin 0 -> 715 bytes .../test_file_.netcoreappversionv3.1.tf | Bin 0 -> 599 bytes .../test_file_.netcoreappversionv5.0.tf | Bin 0 -> 599 bytes 14 files changed, 91 insertions(+), 5 deletions(-) create mode 100644 src/Hyperion.Tests/testfiles/mixed_test_file_.netcoreappversionv2.0.tf create mode 100644 src/Hyperion.Tests/testfiles/mixed_test_file_.netcoreappversionv2.1.tf create mode 100644 src/Hyperion.Tests/testfiles/mixed_test_file_.netcoreappversionv2.2.tf create mode 100644 src/Hyperion.Tests/testfiles/mixed_test_file_.netcoreappversionv3.0.tf create mode 100644 src/Hyperion.Tests/testfiles/mixed_test_file_.netcoreappversionv3.1.tf create mode 100644 src/Hyperion.Tests/testfiles/mixed_test_file_.netcoreappversionv5.0.tf create mode 100644 src/Hyperion.Tests/testfiles/mixed_test_file_.netframeworkversionv4.6.1.tf create mode 100644 src/Hyperion.Tests/testfiles/test_file_.netcoreappversionv3.1.tf create mode 100644 src/Hyperion.Tests/testfiles/test_file_.netcoreappversionv5.0.tf diff --git a/src/Hyperion.Tests/CrossFrameworkSerializationTests.cs b/src/Hyperion.Tests/CrossFrameworkSerializationTests.cs index 69ba00fd..32e9d203 100644 --- a/src/Hyperion.Tests/CrossFrameworkSerializationTests.cs +++ b/src/Hyperion.Tests/CrossFrameworkSerializationTests.cs @@ -2,26 +2,39 @@ using System.Collections.Generic; using System.IO; using System.Linq; +using FluentAssertions; using Hyperion.Tests.Generator; using Xunit; +using Xunit.Abstractions; namespace Hyperion.Tests { public class CrossFrameworkSerializationTests { + private readonly ITestOutputHelper _log; private readonly Serializer _serializer; private readonly CrossFrameworkClass _originalObject; + private readonly CrossFrameworkMixedClass _originalMixedObject; - public CrossFrameworkSerializationTests() + public CrossFrameworkSerializationTests(ITestOutputHelper log) { + _log = log; _serializer = new Serializer(); _originalObject = CrossFrameworkInitializer.Init(); + _originalMixedObject = CrossFrameworkInitializer.InitMixed(); } public static IEnumerable SerializationFiles() { const string defaultOutputPath = CrossFrameworkInitializer.DefaultOutputPath; - var testFiles = Directory.GetFiles(defaultOutputPath, "*.tf"); + var testFiles = Directory.GetFiles(defaultOutputPath, "test_file_.*.tf"); + return testFiles.Select(x => new object[] { x }); + } + + public static IEnumerable MixedSerializationFiles() + { + const string defaultOutputPath = CrossFrameworkInitializer.DefaultOutputPath; + var testFiles = Directory.GetFiles(defaultOutputPath, "mixed_test_file_.*.tf"); return testFiles.Select(x => new object[] { x }); } @@ -32,8 +45,20 @@ public void CanSerializeCrossFramework(string fileName) using (var fileStream = new FileStream(fileName, FileMode.Open)) { var crossFrameworkClass = _serializer.Deserialize(fileStream); + _originalObject.Should() + .Be(crossFrameworkClass, $"[CrossFrameworkClass] {fileName} deserialization should work."); + } + } - Assert.Equal(_originalObject, crossFrameworkClass); + [Theory] + [MemberData(nameof(MixedSerializationFiles))] + public void CanSerializeComplexObjectCrossFramework(string fileName) + { + using (var fileStream = new FileStream(fileName, FileMode.Open)) + { + var deserialized = _serializer.Deserialize(fileStream); + _originalMixedObject.Should() + .Be(deserialized, $"[CrossFrameworkMixedClass] {fileName} deserialization should work."); } } } diff --git a/src/Hyperion.Tests/Generator/CrossFrameworkClass.cs b/src/Hyperion.Tests/Generator/CrossFrameworkClass.cs index 081021c0..41e16cda 100644 --- a/src/Hyperion.Tests/Generator/CrossFrameworkClass.cs +++ b/src/Hyperion.Tests/Generator/CrossFrameworkClass.cs @@ -122,4 +122,47 @@ private bool Equals(CrossFrameworkClass other) && Struct.Equals(other.Struct); } } + + public interface ICrossFrameworkA + { + string Name { get; set; } + } + + public interface ICrossFrameworkB : ICrossFrameworkA + { + string Sound { get; set; } + } + + public class CrossFrameworkBase : ICrossFrameworkB + { + public string Name { get; set; } + public string Sound { get; set; } + } + + public class CrossFrameworkMixedClass : CrossFrameworkBase + { + public Type FriendType { get; set; } + public CrossFrameworkClass Data { get; set; } + + public override bool Equals(object obj) + { + if (!(obj is CrossFrameworkMixedClass other)) + return false; + return other.Equals(this); + } + + protected bool Equals(CrossFrameworkMixedClass other) + { + if (other.Sound != Sound || other.Name != Name) + return false; + return other.Data.Equals(Data); + } + + public override int GetHashCode() + { + int hash = Name.GetHashCode(); + hash = (hash * 397) ^ Sound.GetHashCode(); + return (Data != null ? (hash * 397) ^ Data.GetHashCode() : hash); + } + } } \ No newline at end of file diff --git a/src/Hyperion.Tests/Generator/CrossFrameworkInitializer.cs b/src/Hyperion.Tests/Generator/CrossFrameworkInitializer.cs index dae3431f..b263e7c4 100644 --- a/src/Hyperion.Tests/Generator/CrossFrameworkInitializer.cs +++ b/src/Hyperion.Tests/Generator/CrossFrameworkInitializer.cs @@ -6,6 +6,17 @@ public static class CrossFrameworkInitializer { public const string DefaultOutputPath = "../../../testfiles"; + public static CrossFrameworkMixedClass InitMixed() + { + return new CrossFrameworkMixedClass + { + Name = "Cookie", + Sound = "Bark", + FriendType = typeof(CrossFrameworkClass), + Data = Init() + }; + } + public static CrossFrameworkClass Init() { return new CrossFrameworkClass() diff --git a/src/Hyperion.Tests/Generator/Program.cs b/src/Hyperion.Tests/Generator/Program.cs index c0ae7045..69f597fa 100644 --- a/src/Hyperion.Tests/Generator/Program.cs +++ b/src/Hyperion.Tests/Generator/Program.cs @@ -30,14 +30,21 @@ private static void Main(string[] args) } CrossFrameworkClass crossFrameworkClass = CrossFrameworkInitializer.Init(); + var crossFrameworkMixedClass = CrossFrameworkInitializer.InitMixed(); string fileName = $"test_file_{FrameworkName.ToLowerInvariant()}.tf"; string fullPath = Path.Combine(outputPath, fileName); - using (var fileStream = new FileStream(fullPath, FileMode.Create)) { Serializer.Serialize(crossFrameworkClass, fileStream); } + + fileName = $"mixed_test_file_{FrameworkName.ToLowerInvariant()}.tf"; + fullPath = Path.Combine(outputPath, fileName); + using (var fileStream = new FileStream(fullPath, FileMode.Create)) + { + Serializer.Serialize(crossFrameworkMixedClass, fileStream); + } } } } \ No newline at end of file diff --git a/src/Hyperion.Tests/Hyperion.Tests.csproj b/src/Hyperion.Tests/Hyperion.Tests.csproj index dbf0c2ba..3686b3a8 100644 --- a/src/Hyperion.Tests/Hyperion.Tests.csproj +++ b/src/Hyperion.Tests/Hyperion.Tests.csproj @@ -3,7 +3,7 @@ Exe - net461;netcoreapp3.0 + net461;netcoreapp3.1;net5.0 true latest Hyperion.Tests.Generator.Program diff --git a/src/Hyperion.Tests/testfiles/mixed_test_file_.netcoreappversionv2.0.tf b/src/Hyperion.Tests/testfiles/mixed_test_file_.netcoreappversionv2.0.tf new file mode 100644 index 0000000000000000000000000000000000000000..4cc8d17f28d6e6a8e7e50972dda690e849c7641b GIT binary patch literal 743 zcma)4%}xR_5MB;MFGe3>F5H%NNsz=S2i$*Ah=r2P;(`tM>N(%mncy)t8|oTWlT@A44;&q-tq+w6TyrL zVY9@Y?~d{(K*c#1te#)r-e2|u%72V-gNk=#?u^{##s6~c$~@aJd|x0#W7rr=9%V&GkMj(ry~~Bz8SgM*QYs4r z1W9$CmMaPhEBd^x3RleUC0yqcp%p^owAlvqwSdBKFfEvLB*_?}IeWbMIBVXFnDCsO!%vixCx;9>Rxg;IegfTMAI1Ox literal 0 HcmV?d00001 diff --git a/src/Hyperion.Tests/testfiles/mixed_test_file_.netcoreappversionv2.1.tf b/src/Hyperion.Tests/testfiles/mixed_test_file_.netcoreappversionv2.1.tf new file mode 100644 index 0000000000000000000000000000000000000000..4cc8d17f28d6e6a8e7e50972dda690e849c7641b GIT binary patch literal 743 zcma)4%}xR_5MB;MFGe3>F5H%NNsz=S2i$*Ah=r2P;(`tM>N(%mncy)t8|oTWlT@A44;&q-tq+w6TyrL zVY9@Y?~d{(K*c#1te#)r-e2|u%72V-gNk=#?u^{##s6~c$~@aJd|x0#W7rr=9%V&GkMj(ry~~Bz8SgM*QYs4r z1W9$CmMaPhEBd^x3RleUC0yqcp%p^owAlvqwSdBKFfEvLB*_?}IeWbMIBVXFnDCsO!%vixCx;9>Rxg;IegfTMAI1Ox literal 0 HcmV?d00001 diff --git a/src/Hyperion.Tests/testfiles/mixed_test_file_.netcoreappversionv2.2.tf b/src/Hyperion.Tests/testfiles/mixed_test_file_.netcoreappversionv2.2.tf new file mode 100644 index 0000000000000000000000000000000000000000..4cc8d17f28d6e6a8e7e50972dda690e849c7641b GIT binary patch literal 743 zcma)4%}xR_5MB;MFGe3>F5H%NNsz=S2i$*Ah=r2P;(`tM>N(%mncy)t8|oTWlT@A44;&q-tq+w6TyrL zVY9@Y?~d{(K*c#1te#)r-e2|u%72V-gNk=#?u^{##s6~c$~@aJd|x0#W7rr=9%V&GkMj(ry~~Bz8SgM*QYs4r z1W9$CmMaPhEBd^x3RleUC0yqcp%p^owAlvqwSdBKFfEvLB*_?}IeWbMIBVXFnDCsO!%vixCx;9>Rxg;IegfTMAI1Ox literal 0 HcmV?d00001 diff --git a/src/Hyperion.Tests/testfiles/mixed_test_file_.netcoreappversionv3.0.tf b/src/Hyperion.Tests/testfiles/mixed_test_file_.netcoreappversionv3.0.tf new file mode 100644 index 0000000000000000000000000000000000000000..4cc8d17f28d6e6a8e7e50972dda690e849c7641b GIT binary patch literal 743 zcma)4%}xR_5MB;MFGe3>F5H%NNsz=S2i$*Ah=r2P;(`tM>N(%mncy)t8|oTWlT@A44;&q-tq+w6TyrL zVY9@Y?~d{(K*c#1te#)r-e2|u%72V-gNk=#?u^{##s6~c$~@aJd|x0#W7rr=9%V&GkMj(ry~~Bz8SgM*QYs4r z1W9$CmMaPhEBd^x3RleUC0yqcp%p^owAlvqwSdBKFfEvLB*_?}IeWbMIBVXFnDCsO!%vixCx;9>Rxg;IegfTMAI1Ox literal 0 HcmV?d00001 diff --git a/src/Hyperion.Tests/testfiles/mixed_test_file_.netcoreappversionv3.1.tf b/src/Hyperion.Tests/testfiles/mixed_test_file_.netcoreappversionv3.1.tf new file mode 100644 index 0000000000000000000000000000000000000000..4cc8d17f28d6e6a8e7e50972dda690e849c7641b GIT binary patch literal 743 zcma)4%}xR_5MB;MFGe3>F5H%NNsz=S2i$*Ah=r2P;(`tM>N(%mncy)t8|oTWlT@A44;&q-tq+w6TyrL zVY9@Y?~d{(K*c#1te#)r-e2|u%72V-gNk=#?u^{##s6~c$~@aJd|x0#W7rr=9%V&GkMj(ry~~Bz8SgM*QYs4r z1W9$CmMaPhEBd^x3RleUC0yqcp%p^owAlvqwSdBKFfEvLB*_?}IeWbMIBVXFnDCsO!%vixCx;9>Rxg;IegfTMAI1Ox literal 0 HcmV?d00001 diff --git a/src/Hyperion.Tests/testfiles/mixed_test_file_.netcoreappversionv5.0.tf b/src/Hyperion.Tests/testfiles/mixed_test_file_.netcoreappversionv5.0.tf new file mode 100644 index 0000000000000000000000000000000000000000..4cc8d17f28d6e6a8e7e50972dda690e849c7641b GIT binary patch literal 743 zcma)4%}xR_5MB;MFGe3>F5H%NNsz=S2i$*Ah=r2P;(`tM>N(%mncy)t8|oTWlT@A44;&q-tq+w6TyrL zVY9@Y?~d{(K*c#1te#)r-e2|u%72V-gNk=#?u^{##s6~c$~@aJd|x0#W7rr=9%V&GkMj(ry~~Bz8SgM*QYs4r z1W9$CmMaPhEBd^x3RleUC0yqcp%p^owAlvqwSdBKFfEvLB*_?}IeWbMIBVXFnDCsO!%vixCx;9>Rxg;IegfTMAI1Ox literal 0 HcmV?d00001 diff --git a/src/Hyperion.Tests/testfiles/mixed_test_file_.netframeworkversionv4.6.1.tf b/src/Hyperion.Tests/testfiles/mixed_test_file_.netframeworkversionv4.6.1.tf new file mode 100644 index 0000000000000000000000000000000000000000..8de4aed34223ccca678f6c4e3f36cb693ef0b862 GIT binary patch literal 715 zcma)4%}xR_5MB;MFGe3>JaAh!OM)auIp78~Ch7rSpe(b{&}~WEMMzARc-N=%J$!^Z z#UBDe!z7)rO*`MrH&fRMg5YK`Ma`9r9?@76U86+JtkO}Ul`%cda(q&Ha>wU5OawC~ zgv}6lxj)NJf{Jr4SU$hLy}uj=wEs2Y4JzJ|xeIceiT|v%D~o))%Btr$CD&gVi+R+Y zr#Q8wJA~Y%N((*+YlK(}j(jH|M`PFsDXPAX>gZ9CqqO&h5dSb7CrnCZVSpg%rBCh3 zl3+>8+p=`!>_Nh9ArV?3G|rn%DumL59Wx1yRvgB03>_gj4#8@rrUnF)Lpm{`? zlgwDWm7}0wXBUIWfh0jyj`fr)7bf?n? zlgwDWm7}0wXBUIWfh0jyj`fr)7bf?n Date: Thu, 25 Mar 2021 01:34:19 +0700 Subject: [PATCH 2/4] Update build system to support .NET 3.1 and 5.0 --- build-system/azure-pipeline.template.yaml | 9 +++++++++ 1 file changed, 9 insertions(+) diff --git a/build-system/azure-pipeline.template.yaml b/build-system/azure-pipeline.template.yaml index feba5487..38166d80 100644 --- a/build-system/azure-pipeline.template.yaml +++ b/build-system/azure-pipeline.template.yaml @@ -16,6 +16,15 @@ jobs: clean: false # whether to fetch clean each time submodules: recursive # set to 'true' for a single level of submodules or 'recursive' to get submodules of submodules persistCredentials: true + - task: UseDotNet@2 + displayName: 'Use .NET 5 SDK 5.0.101' + inputs: + version: 5.0.101 + - task: UseDotNet@2 + displayName: 'Use .NET Core Runtime 3.1.10' + inputs: + packageType: runtime + version: 3.1.10 # Linux or macOS - task: Bash@3 displayName: Linux / OSX Build From 6b9543d79cad6153e58c3b31cf0113df8013bebf Mon Sep 17 00:00:00 2001 From: Gregorius Soedharmo Date: Thu, 25 Mar 2021 01:48:57 +0700 Subject: [PATCH 3/4] Add FriendType comparison in Equal() --- src/Hyperion.Tests/Generator/CrossFrameworkClass.cs | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/src/Hyperion.Tests/Generator/CrossFrameworkClass.cs b/src/Hyperion.Tests/Generator/CrossFrameworkClass.cs index 41e16cda..17d3966b 100644 --- a/src/Hyperion.Tests/Generator/CrossFrameworkClass.cs +++ b/src/Hyperion.Tests/Generator/CrossFrameworkClass.cs @@ -153,7 +153,7 @@ public override bool Equals(object obj) protected bool Equals(CrossFrameworkMixedClass other) { - if (other.Sound != Sound || other.Name != Name) + if (other.Sound != Sound || other.Name != Name || other.FriendType != FriendType) return false; return other.Data.Equals(Data); } From 4bc1c7a3134e23b1527f33e6c75a1102c21151a1 Mon Sep 17 00:00:00 2001 From: Gregorius Soedharmo Date: Thu, 25 Mar 2021 02:49:14 +0700 Subject: [PATCH 4/4] update build system --- build.fsx | 171 +++++++++++++++++++++++++++++++++++++++--------------- build.ps1 | 56 ++---------------- build.sh | 17 ------ 3 files changed, 128 insertions(+), 116 deletions(-) diff --git a/build.fsx b/build.fsx index 33ba702c..c3e5b00d 100644 --- a/build.fsx +++ b/build.fsx @@ -8,6 +8,7 @@ open System.Text open Fake open Fake.DotNetCli open Fake.DocFxHelper +open Fake.NuGet.Install // Information about the project for Nuget and Assembly info files let product = "Hyperion" @@ -18,27 +19,42 @@ let signingName = "Hyperion" let signingDescription = "A high performance polymorphic serializer for the .NET framework" let signingUrl = "" +// Directories +let toolsDir = __SOURCE_DIRECTORY__ @@ "tools" +let output = __SOURCE_DIRECTORY__ @@ "bin" +let outputTests = __SOURCE_DIRECTORY__ @@ "TestResults" +let outputPerfTests = __SOURCE_DIRECTORY__ @@ "PerfResults" +let outputBinaries = output @@ "binaries" +let outputBinariesNet461 = outputBinaries @@ "net461" +let outputBinariesNetStandard = outputBinaries @@ "netstandard2.0" +let outputBinariesNet = outputBinaries @@ "net5.0" +let outputNuGet = output @@ "nuget" // Read release notes and version let solutionFile = FindFirstMatchingFile "*.sln" __SOURCE_DIRECTORY__ // dynamically look up the solution let buildNumber = environVarOrDefault "BUILD_NUMBER" "0" let hasTeamCity = (not (buildNumber = "0")) // check if we have the TeamCity environment variable for build # set let preReleaseVersionSuffix = "beta" + (if (not (buildNumber = "0")) then (buildNumber) else DateTime.UtcNow.Ticks.ToString()) -let versionSuffix = - match (getBuildParam "nugetprerelease") with - | "dev" -> preReleaseVersionSuffix - | _ -> "" let releaseNotes = - File.ReadLines "./RELEASE_NOTES.md" + File.ReadLines (__SOURCE_DIRECTORY__ @@ "RELEASE_NOTES.md") |> ReleaseNotesHelper.parseReleaseNotes -// Directories -let toolsDir = __SOURCE_DIRECTORY__ @@ "tools" -let output = __SOURCE_DIRECTORY__ @@ "bin" -let outputTests = __SOURCE_DIRECTORY__ @@ "TestResults" -let outputPerfTests = __SOURCE_DIRECTORY__ @@ "PerfResults" -let outputNuGet = output @@ "nuget" +let versionFromReleaseNotes = + match releaseNotes.SemVer.PreRelease with + | Some r -> r.Origin + | None -> "" + +let versionSuffix = + match (getBuildParam "nugetprerelease") with + | "dev" -> preReleaseVersionSuffix + | "" -> versionFromReleaseNotes + | str -> str + +// Configuration values for tests +let testNetFrameworkVersion = "net461" +let testNetCoreVersion = "netcoreapp3.1" +let testNetVersion = "net5.0" Target "Clean" (fun _ -> ActivateFinalTarget "KillCreatedProcesses" @@ -46,8 +62,15 @@ Target "Clean" (fun _ -> CleanDir output CleanDir outputTests CleanDir outputPerfTests + CleanDir outputBinaries CleanDir outputNuGet + CleanDir outputBinariesNet461 + CleanDir outputBinariesNetStandard + CleanDir outputBinariesNet CleanDir "docs/_site" + + CleanDirs !! "./**/bin" + CleanDirs !! "./**/obj" ) Target "AssemblyInfo" (fun _ -> @@ -56,17 +79,20 @@ Target "AssemblyInfo" (fun _ -> ) Target "Build" (fun _ -> + let additionalArgs = if versionSuffix.Length > 0 then [sprintf "/p:VersionSuffix=%s" versionSuffix] else [] DotNetCli.Build (fun p -> { p with Project = solutionFile - Configuration = configuration }) // "Rebuild" + Configuration = configuration + AdditionalArgs = additionalArgs }) // "Rebuild" ) //-------------------------------------------------------------------------------- // Tests targets //-------------------------------------------------------------------------------- + module internal ResultHandling = let (|OK|Failure|) = function | 0 -> OK @@ -94,8 +120,32 @@ Target "RunTests" (fun _ -> let runSingleProject project = let arguments = match (hasTeamCity) with - | true -> (sprintf "test -c Release --no-build --logger:trx --logger:\"console;verbosity=normal\" --results-directory %s -- -parallel none -teamcity" (outputTests)) - | false -> (sprintf "test -c Release --no-build --logger:trx --logger:\"console;verbosity=normal\" --results-directory %s -- -parallel none" (outputTests)) + | true -> (sprintf "test -c Release --no-build --logger:trx --logger:\"console;verbosity=normal\" --framework %s --results-directory \"%s\" -- -parallel none -teamcity" testNetFrameworkVersion outputTests) + | false -> (sprintf "test -c Release --no-build --logger:trx --logger:\"console;verbosity=normal\" --framework %s --results-directory \"%s\" -- -parallel none" testNetFrameworkVersion outputTests) + + let result = ExecProcess(fun info -> + info.FileName <- "dotnet" + info.WorkingDirectory <- (Directory.GetParent project).FullName + info.Arguments <- arguments) (TimeSpan.FromMinutes 30.0) + + ResultHandling.failBuildIfXUnitReportedError TestRunnerErrorLevel.Error result + + CreateDir outputTests + projects |> Seq.iter (log) + projects |> Seq.iter (runSingleProject) +) + +Target "RunTestsNetCore" (fun _ -> + let projects = + match (isWindows) with + | true -> !! "./src/**/*.Tests.csproj" + | _ -> !! "./src/**/*.Tests.csproj" // if you need to filter specs for Linux vs. Windows, do it here + + let runSingleProject project = + let arguments = + match (hasTeamCity) with + | true -> (sprintf "test -c Release --no-build --logger:trx --logger:\"console;verbosity=normal\" --framework %s --results-directory \"%s\" -- -parallel none -teamcity" testNetCoreVersion outputTests) + | false -> (sprintf "test -c Release --no-build --logger:trx --logger:\"console;verbosity=normal\" --framework %s --results-directory \"%s\" -- -parallel none" testNetCoreVersion outputTests) let result = ExecProcess(fun info -> info.FileName <- "dotnet" @@ -104,44 +154,64 @@ Target "RunTests" (fun _ -> ResultHandling.failBuildIfXUnitReportedError TestRunnerErrorLevel.Error result + CreateDir outputTests + projects |> Seq.iter (log) + projects |> Seq.iter (runSingleProject) +) + +Target "RunTestsNet" (fun _ -> + let projects = + match (isWindows) with + | true -> !! "./src/**/*.Tests.csproj" + | _ -> !! "./src/**/*.Tests.csproj" // if you need to filter specs for Linux vs. Windows, do it here + + let runSingleProject project = + let arguments = + match (hasTeamCity) with + | true -> (sprintf "test -c Release --no-build --logger:trx --logger:\"console;verbosity=normal\" --framework %s --results-directory \"%s\" -- -parallel none -teamcity" testNetVersion outputTests) + | false -> (sprintf "test -c Release --no-build --logger:trx --logger:\"console;verbosity=normal\" --framework %s --results-directory \"%s\" -- -parallel none" testNetVersion outputTests) + + let result = ExecProcess(fun info -> + info.FileName <- "dotnet" + info.WorkingDirectory <- (Directory.GetParent project).FullName + info.Arguments <- arguments) (TimeSpan.FromMinutes 30.0) + + ResultHandling.failBuildIfXUnitReportedError TestRunnerErrorLevel.Error result + + CreateDir outputTests projects |> Seq.iter (log) projects |> Seq.iter (runSingleProject) ) Target "NBench" <| fun _ -> - let nbenchTestPath = findToolInSubPath "NBench.Runner.exe" (toolsDir @@ "NBench.Runner*") - printfn "Using NBench.Runner: %s" nbenchTestPath - - let nbenchTestAssemblies = !! "./src/**/bin/**/*Tests.Performance.dll" // doesn't support .NET Core at the moment - - let runNBench assembly = - let includes = getBuildParam "include" - let excludes = getBuildParam "exclude" - let teamcityStr = (getBuildParam "teamcity") - let enableTeamCity = - match teamcityStr with - | null -> false - | "" -> false - | _ -> bool.Parse teamcityStr - - let args = StringBuilder() - |> append assembly - |> append (sprintf "output-directory=\"%s\"" outputPerfTests) - |> append (sprintf "concurrent=\"%b\"" true) - |> append (sprintf "trace=\"%b\"" true) - |> append (sprintf "teamcity=\"%b\"" enableTeamCity) - |> appendIfNotNullOrEmpty includes "include=" - |> appendIfNotNullOrEmpty excludes "include=" + ensureDirectory outputPerfTests + let projects = + match (isWindows) with + | true -> !! "./src/**/*Tests.Performance.csproj" + | _ -> !! "./src/**/*Tests.Performance.csproj" // if you need to filter specs for Linux vs. Windows, do it here + + projects |> Seq.iter(fun project -> + let args = new StringBuilder() + |> append "run" + |> append "--no-build" + |> append "-c" + |> append configuration + |> append " -- " + |> append "--output" + |> append outputPerfTests + |> append "--concurrent" + |> append "true" + |> append "--trace" + |> append "true" + |> append "--diagnostic" |> toText - let result = ExecProcess(fun info -> - info.FileName <- nbenchTestPath - info.WorkingDirectory <- (Path.GetDirectoryName (FullName nbenchTestPath)) - info.Arguments <- args) (System.TimeSpan.FromMinutes 45.0) (* Reasonably long-running task. *) - - if result <> 0 then failwithf "NBench.Runner failed. %s %s" nbenchTestPath args - - nbenchTestAssemblies |> Seq.iter runNBench + let result = ExecProcess(fun info -> + info.FileName <- "dotnet" + info.WorkingDirectory <- (Directory.GetParent project).FullName + info.Arguments <- args) (System.TimeSpan.FromMinutes 15.0) (* Reasonably long-running task. *) + if result <> 0 then failwithf "NBench.Runner failed. %s %s" "dotnet" args + ) //-------------------------------------------------------------------------------- @@ -301,23 +371,30 @@ Target "Help" <| fun _ -> Target "BuildRelease" DoNothing Target "All" DoNothing Target "Nuget" DoNothing +Target "RunTestsFull" DoNothing +Target "RunTestsNetCoreFull" DoNothing // build dependencies "Clean" ==> "AssemblyInfo" ==> "Build" ==> "BuildRelease" // tests dependencies "Build" ==> "RunTests" +"Build" ==> "RunTestsNetCore" +"Build" ==> "RunTestsNet" +"Build" ==> "NBench" // nuget dependencies -"Clean" ==> "Build" ==> "CreateNuget" +"BuildRelease" ==> "CreateNuget" "CreateNuget" ==> "SignPackages" ==> "PublishNuget" ==> "Nuget" // docs -"Clean" ==> "BuildRelease" ==> "Docfx" +"BuildRelease" ==> "Docfx" // all "BuildRelease" ==> "All" "RunTests" ==> "All" +"RunTestsNetCore" ==> "All" +"RunTestsNet" ==> "All" "NBench" ==> "All" "Nuget" ==> "All" diff --git a/build.ps1 b/build.ps1 index d2581ca4..953f4cc9 100644 --- a/build.ps1 +++ b/build.ps1 @@ -29,14 +29,11 @@ Param( [string[]]$ScriptArgs ) -$FakeVersion = "4.61.2" -$DotNetChannel = "LTS"; -$DotNetVersion = "3.0.100"; -$DotNetInstallerUri = "https://dot.net/v1/dotnet-install.ps1"; -$NugetVersion = "4.1.0"; +$FakeVersion = "4.63.2" +$NugetVersion = "5.8.0"; $NugetUrl = "https://dist.nuget.org/win-x86-commandline/v$NugetVersion/nuget.exe" -$ProtobufVersion = "3.2.0" -$DocfxVersion = "2.40.5" +$ProtobufVersion = "3.13.0" +$DocfxVersion = "2.48.1" # Make sure tools folder exists $PSScriptRoot = Split-Path $MyInvocation.MyCommand.Path -Parent @@ -46,51 +43,6 @@ if (!(Test-Path $ToolPath)) { New-Item -Path $ToolPath -Type directory | out-null } -########################################################################### -# INSTALL .NET CORE CLI -########################################################################### - -Function Remove-PathVariable([string]$VariableToRemove) -{ - $path = [Environment]::GetEnvironmentVariable("PATH", "User") - if ($path -ne $null) - { - $newItems = $path.Split(';', [StringSplitOptions]::RemoveEmptyEntries) | Where-Object { "$($_)" -inotlike $VariableToRemove } - [Environment]::SetEnvironmentVariable("PATH", [System.String]::Join(';', $newItems), "User") - } - - $path = [Environment]::GetEnvironmentVariable("PATH", "Process") - if ($path -ne $null) - { - $newItems = $path.Split(';', [StringSplitOptions]::RemoveEmptyEntries) | Where-Object { "$($_)" -inotlike $VariableToRemove } - [Environment]::SetEnvironmentVariable("PATH", [System.String]::Join(';', $newItems), "Process") - } -} - -# Get .NET Core CLI path if installed. -$FoundDotNetCliVersion = $null; -if (Get-Command dotnet -ErrorAction SilentlyContinue) { - $FoundDotNetCliVersion = dotnet --version; - $env:DOTNET_SKIP_FIRST_TIME_EXPERIENCE=1 - $env:DOTNET_CLI_TELEMETRY_OPTOUT=1 -} - -if($FoundDotNetCliVersion -ne $DotNetVersion) { - $InstallPath = Join-Path $PSScriptRoot ".dotnet" - if (!(Test-Path $InstallPath)) { - mkdir -Force $InstallPath | Out-Null; - } - (New-Object System.Net.WebClient).DownloadFile($DotNetInstallerUri, "$InstallPath\dotnet-install.ps1"); - & $InstallPath\dotnet-install.ps1 -Channel $DotNetChannel -Version $DotNetVersion -InstallDir $InstallPath -Architecture x64; - - Remove-PathVariable "$InstallPath" - $env:PATH = "$InstallPath;$env:PATH" - $env:DOTNET_SKIP_FIRST_TIME_EXPERIENCE=1 - $env:DOTNET_CLI_TELEMETRY_OPTOUT=1 - $env:DOTNET_ROOT=$InstallPath -} - - ########################################################################### # INSTALL NUGET ########################################################################### diff --git a/build.sh b/build.sh index 230cfe96..05d67196 100644 --- a/build.sh +++ b/build.sh @@ -41,23 +41,6 @@ if [ ! -d "$TOOLS_DIR" ]; then mkdir "$TOOLS_DIR" fi -########################################################################### -# INSTALL .NET CORE CLI -########################################################################### - -echo "Installing .NET CLI..." -if [ ! -d "$SCRIPT_DIR/.dotnet" ]; then - mkdir "$SCRIPT_DIR/.dotnet" -fi -curl -Lsfo "$SCRIPT_DIR/.dotnet/dotnet-install.sh" $DOTNET_INSTALLER_URL -bash "$SCRIPT_DIR/.dotnet/dotnet-install.sh" --version $DOTNET_VERSION --channel $DOTNET_CHANNEL --install-dir .dotnet --no-path -export PATH="$SCRIPT_DIR/.dotnet":$PATH -export DOTNET_SKIP_FIRST_TIME_EXPERIENCE=1 -export DOTNET_CLI_TELEMETRY_OPTOUT=1 -chmod -R 0755 ".dotnet" -"$SCRIPT_DIR/.dotnet/dotnet" --info - - ########################################################################### # INSTALL NUGET ###########################################################################