Unverified Commit db1d4dc4 authored by Jan Tattermusch's avatar Jan Tattermusch Committed by GitHub

Merge pull request #5876 from jtattermusch/csharp_win_tests

C# testing improvements
parents 93533f78 60a889e0
...@@ -57,6 +57,7 @@ csharp_EXTRA_DIST= \ ...@@ -57,6 +57,7 @@ csharp_EXTRA_DIST= \
csharp/README.md \ csharp/README.md \
csharp/build_packages.bat \ csharp/build_packages.bat \
csharp/build_tools.sh \ csharp/build_tools.sh \
csharp/buildall.bat \
csharp/buildall.sh \ csharp/buildall.sh \
csharp/generate_protos.sh \ csharp/generate_protos.sh \
csharp/install_dotnet_sdk.ps1 \ csharp/install_dotnet_sdk.ps1 \
......
...@@ -38,7 +38,7 @@ dotnet restore ...@@ -38,7 +38,7 @@ dotnet restore
dotnet build -c %configuration% || goto error dotnet build -c %configuration% || goto error
echo Testing C# echo Testing C#
dotnet test -c %configuration% -f netcoreapp1.0 Google.Protobuf.Test\Google.Protobuf.Test.csproj || goto error dotnet test -c %configuration% -f netcoreapp2.1 Google.Protobuf.Test\Google.Protobuf.Test.csproj || goto error
dotnet test -c %configuration% -f net451 Google.Protobuf.Test\Google.Protobuf.Test.csproj || goto error dotnet test -c %configuration% -f net451 Google.Protobuf.Test\Google.Protobuf.Test.csproj || goto error
goto :EOF goto :EOF
......
@rem Builds Google.Protobuf and runs the tests
dotnet build src/Google.Protobuf.sln || goto :error
echo Running tests.
dotnet test src/Google.Protobuf.Test/Google.Protobuf.Test.csproj || goto :error
goto :EOF
:error
echo Failed!
exit /b %errorlevel%
...@@ -10,8 +10,8 @@ dotnet restore $SRC/Google.Protobuf.sln ...@@ -10,8 +10,8 @@ dotnet restore $SRC/Google.Protobuf.sln
dotnet build -c $CONFIG $SRC/Google.Protobuf.sln dotnet build -c $CONFIG $SRC/Google.Protobuf.sln
echo Running tests. echo Running tests.
# Only test netcoreapp1.0, which uses the .NET Core runtime. # Only test netcoreapp2.1, which uses the .NET Core runtime.
# If we want to test the .NET 4.5 version separately, we could # If we want to test the .NET 4.5 version separately, we could
# run Mono explicitly. However, we don't have any differences between # run Mono explicitly. However, we don't have any differences between
# the .NET 4.5 and netstandard1.0 assemblies. # the .NET 4.5 and netstandard2.1 assemblies.
dotnet test -c $CONFIG -f netcoreapp1.0 $SRC/Google.Protobuf.Test/Google.Protobuf.Test.csproj dotnet test -c $CONFIG -f netcoreapp2.1 $SRC/Google.Protobuf.Test/Google.Protobuf.Test.csproj
...@@ -750,7 +750,8 @@ namespace Google.Protobuf.Collections ...@@ -750,7 +750,8 @@ namespace Google.Protobuf.Collections
var list2 = new RepeatedField<double> { SampleNaNs.Regular, SampleNaNs.PayloadFlipped }; var list2 = new RepeatedField<double> { SampleNaNs.Regular, SampleNaNs.PayloadFlipped };
var list3 = new RepeatedField<double> { SampleNaNs.Regular, SampleNaNs.SignallingFlipped }; var list3 = new RepeatedField<double> { SampleNaNs.Regular, SampleNaNs.SignallingFlipped };
EqualityTester.AssertInequality(list1, list2); // All SampleNaNs have the same hashcode under certain targets (e.g. netcoreapp2.1)
EqualityTester.AssertInequality(list1, list2, checkHashcode: false);
EqualityTester.AssertEquality(list1, list3); EqualityTester.AssertEquality(list1, list3);
Assert.True(list1.Contains(SampleNaNs.SignallingFlipped)); Assert.True(list1.Contains(SampleNaNs.SignallingFlipped));
Assert.False(list2.Contains(SampleNaNs.SignallingFlipped)); Assert.False(list2.Contains(SampleNaNs.SignallingFlipped));
......
...@@ -49,13 +49,14 @@ namespace Google.Protobuf ...@@ -49,13 +49,14 @@ namespace Google.Protobuf
Assert.AreEqual(first.GetHashCode(), second.GetHashCode()); Assert.AreEqual(first.GetHashCode(), second.GetHashCode());
} }
public static void AssertInequality<T>(T first, T second) where T : IEquatable<T> public static void AssertInequality<T>(T first, T second, bool checkHashcode = true) where T : IEquatable<T>
{ {
Assert.IsFalse(first.Equals(second)); Assert.IsFalse(first.Equals(second));
Assert.IsFalse(first.Equals((object) second)); Assert.IsFalse(first.Equals((object) second));
// While this isn't a requirement, the chances of this test failing due to // While this isn't a requirement, the chances of this test failing due to
// coincidence rather than a bug are very small. // coincidence rather than a bug are very small.
if (first != null && second != null) // For such rare cases, an argument can be used to disable the check.
if (checkHashcode && first != null && second != null)
{ {
Assert.AreNotEqual(first.GetHashCode(), second.GetHashCode()); Assert.AreNotEqual(first.GetHashCode(), second.GetHashCode());
} }
......
...@@ -7,4 +7,8 @@ cd csharp ...@@ -7,4 +7,8 @@ cd csharp
powershell -File install_dotnet_sdk.ps1 powershell -File install_dotnet_sdk.ps1
set PATH=%LOCALAPPDATA%\Microsoft\dotnet;%PATH% set PATH=%LOCALAPPDATA%\Microsoft\dotnet;%PATH%
@rem Disable some unwanted dotnet options
set DOTNET_SKIP_FIRST_TIME_EXPERIENCE=true
set DOTNET_CLI_TELEMETRY_OPTOUT=true
call build_packages.bat call build_packages.bat
@rem enter repo root
cd /d %~dp0\..\..\..
cd csharp
@rem Install dotnet SDK
powershell -File install_dotnet_sdk.ps1
set PATH=%LOCALAPPDATA%\Microsoft\dotnet;%PATH%
@rem Disable some unwanted dotnet options
set DOTNET_SKIP_FIRST_TIME_EXPERIENCE=true
set DOTNET_CLI_TELEMETRY_OPTOUT=true
call buildall.bat
# Config file for running tests in Kokoro
# Location of the build script in repository
build_file: "protobuf/kokoro/windows/csharp/build.bat"
timeout_mins: 1440
...@@ -117,6 +117,12 @@ build_csharp() { ...@@ -117,6 +117,12 @@ build_csharp() {
internal_build_cpp internal_build_cpp
NUGET=/usr/local/bin/nuget.exe NUGET=/usr/local/bin/nuget.exe
# Disable some unwanted dotnet options
export DOTNET_SKIP_FIRST_TIME_EXPERIENCE=true
export DOTNET_CLI_TELEMETRY_OPTOUT=true
# TODO(jtattermusch): is this still needed with "first time experience"
# disabled?
# Perform "dotnet new" once to get the setup preprocessing out of the # Perform "dotnet new" once to get the setup preprocessing out of the
# way. That spews a lot of output (including backspaces) into logs # way. That spews a lot of output (including backspaces) into logs
# otherwise, and can cause problems. It doesn't matter if this step # otherwise, and can cause problems. It doesn't matter if this step
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment