Browse Source

Allow the integration tests to run on .NET Framework (#1286)

* Allow the integration tests to run on .NET Framework

* Update appveyor.yml

* Update appveyor.yml

---------

Co-authored-by: Wojciech Nagórski <wojtpl2@gmail.com>
Rob Hague 1 year ago
parent
commit
bfe6718fce

+ 3 - 2
appveyor.yml

@@ -19,13 +19,14 @@ for:
           
           
   build_script:
   build_script:
     - echo build
     - echo build
-    - dotnet build Renci.SshNet.sln -c Debug -f net8.0
+    - dotnet build -f net8.0 -c Debug test/Renci.SshNet.Tests/Renci.SshNet.Tests.csproj
+    - dotnet build -f net8.0 -c Debug test/Renci.SshNet.IntegrationTests/Renci.SshNet.IntegrationTests.csproj
 
 
   test_script:
   test_script:
     - sh: echo "Run unit tests"
     - sh: echo "Run unit tests"
     - sh: dotnet test -f net8.0 -c Debug --no-restore --no-build --results-directory artifacts --logger Appveyor --logger "console;verbosity=normal" --logger "liquid.md;LogFileName=linux_unit_test_net_8_report.md" -p:CollectCoverage=true -p:CoverletOutputFormat=cobertura -p:CoverletOutput=../../artifacts/linux_unit_test_net_8_coverage.xml test/Renci.SshNet.Tests/Renci.SshNet.Tests.csproj
     - sh: dotnet test -f net8.0 -c Debug --no-restore --no-build --results-directory artifacts --logger Appveyor --logger "console;verbosity=normal" --logger "liquid.md;LogFileName=linux_unit_test_net_8_report.md" -p:CollectCoverage=true -p:CoverletOutputFormat=cobertura -p:CoverletOutput=../../artifacts/linux_unit_test_net_8_coverage.xml test/Renci.SshNet.Tests/Renci.SshNet.Tests.csproj
     - sh: echo "Run integration tests"
     - sh: echo "Run integration tests"
-    - sh: dotnet test -c Debug --no-restore --no-build --results-directory artifacts --logger Appveyor --logger "console;verbosity=normal" --logger "liquid.md;LogFileName=linux_integration_test_net_8_report.md" -p:CollectCoverage=true -p:CoverletOutputFormat=cobertura -p:CoverletOutput=../../artifacts/linux_integration_test_net_8_coverage.xml test/Renci.SshNet.IntegrationTests/Renci.SshNet.IntegrationTests.csproj
+    - sh: dotnet test -f net8.0 -c Debug --no-restore --no-build --results-directory artifacts --logger Appveyor --logger "console;verbosity=normal" --logger "liquid.md;LogFileName=linux_integration_test_net_8_report.md" -p:CollectCoverage=true -p:CoverletOutputFormat=cobertura -p:CoverletOutput=../../artifacts/linux_integration_test_net_8_coverage.xml test/Renci.SshNet.IntegrationTests/Renci.SshNet.IntegrationTests.csproj
 
 
 #  on_failure:
 #  on_failure:
 #    - sh: appveyor PushArtifact artifacts/tcpdump.pcap
 #    - sh: appveyor PushArtifact artifacts/tcpdump.pcap

+ 0 - 23
test/Renci.SshNet.IntegrationTests/App.config

@@ -1,23 +0,0 @@
-<?xml version="1.0" encoding="utf-8"?>
-<configuration>
-  <system.diagnostics>
-    <trace autoflush="true"/>
-    <sources>
-      <source name="SshNet.Logging" switchName="SshNetSwitch" switchType="System.Diagnostics.SourceSwitch">
-        <listeners>
-          <!--<add name="SshDotNetTraceFile" />-->
-          <!--<add name="Console"/>-->
-        </listeners>
-      </source>
-    </sources>
-    <switches>
-      <add name="SshNetSwitch" value="Verbose"/>
-    </switches>
-    <sharedListeners>
-      <add name="SshDotNetTraceFile" type="System.Diagnostics.TextWriterTraceListener" initializeData="SshNetTrace.log">
-        <!--<filter type="System.Diagnostics.EventTypeFilter" initializeData="Warning" />-->
-      </add>
-      <add name="Console" type="System.Diagnostics.ConsoleTraceListener" traceOutputOptions="DateTime,Timestamp,ThreadId"/>
-    </sharedListeners>
-  </system.diagnostics>
-</configuration>

+ 1 - 3
test/Renci.SshNet.IntegrationTests/Common/DateTimeExtensions.cs

@@ -4,9 +4,7 @@
     {
     {
         public static DateTime TruncateToWholeSeconds(this DateTime dateTime)
         public static DateTime TruncateToWholeSeconds(this DateTime dateTime)
         {
         {
-            return dateTime.AddMilliseconds(-dateTime.Millisecond)
-                           .AddMicroseconds(-dateTime.Microsecond)
-                           .AddTicks(-(dateTime.Nanosecond / 100));
+            return new DateTime(dateTime.Ticks - (dateTime.Ticks % TimeSpan.TicksPerSecond), dateTime.Kind);
         }
         }
     }
     }
 }
 }

+ 4 - 0
test/Renci.SshNet.IntegrationTests/HostConfig.cs

@@ -29,7 +29,11 @@ namespace Renci.SshNet.IntegrationTests
                     while ((line = sr.ReadLine()) != null)
                     while ((line = sr.ReadLine()) != null)
                     {
                     {
                         // skip comments
                         // skip comments
+#if NET
                         if (line.StartsWith('#'))
                         if (line.StartsWith('#'))
+#else
+                        if (line.StartsWith("#"))
+#endif
                         {
                         {
                             continue;
                             continue;
                         }
                         }

+ 9 - 6
test/Renci.SshNet.IntegrationTests/OldIntegrationTests/ForwardedPortLocalTest.cs

@@ -1,4 +1,7 @@
 using System.Diagnostics;
 using System.Diagnostics;
+#if !NET6_0_OR_GREATER
+using System.Net;
+#endif
 
 
 using Renci.SshNet.Common;
 using Renci.SshNet.Common;
 
 
@@ -46,8 +49,8 @@ namespace Renci.SshNet.IntegrationTests.OldIntegrationTests
                                                  .GetAwaiter()
                                                  .GetAwaiter()
                                                  .GetResult();
                                                  .GetResult();
 #else
 #else
-                            var request = (HttpWebRequest) WebRequest.Create(url);
-                            var response = (HttpWebResponse) request.GetResponse();
+                        var request = (HttpWebRequest) WebRequest.Create(url);
+                        var response = (HttpWebResponse) request.GetResponse();
 #endif // NET6_0_OR_GREATER
 #endif // NET6_0_OR_GREATER
 
 
                         Assert.IsNotNull(response);
                         Assert.IsNotNull(response);
@@ -122,10 +125,10 @@ namespace Renci.SshNet.IntegrationTests.OldIntegrationTests
                                      {
                                      {
                                          var data = ReadStream(response.Content.ReadAsStream());
                                          var data = ReadStream(response.Content.ReadAsStream());
 #else
 #else
-                                        var request = (HttpWebRequest) WebRequest.Create("http://localhost:8084");
-                                        using (var response = (HttpWebResponse) request.GetResponse())
-                                        {
-                                            var data = ReadStream(response.GetResponseStream());
+                                     var request = (HttpWebRequest) WebRequest.Create("http://localhost:8084");
+                                     using (var response = (HttpWebResponse) request.GetResponse())
+                                     {
+                                         var data = ReadStream(response.GetResponseStream());
 #endif // NET6_0_OR_GREATER
 #endif // NET6_0_OR_GREATER
                                          var end = DateTime.Now;
                                          var end = DateTime.Now;
 
 

+ 5 - 1
test/Renci.SshNet.IntegrationTests/OldIntegrationTests/SftpClientTest.cs

@@ -14,7 +14,11 @@ namespace Renci.SshNet.IntegrationTests.OldIntegrationTests
         {
         {
             using (FileStream file = new FileStream(fileName, FileMode.Open))
             using (FileStream file = new FileStream(fileName, FileMode.Open))
             {
             {
-                var hash = MD5.HashData(file);
+                byte[] hash;
+                using (var md5 = MD5.Create())
+                {
+                    hash = md5.ComputeHash(file);
+                }
 
 
                 file.Close();
                 file.Close();
 
 

+ 0 - 11
test/Renci.SshNet.IntegrationTests/Program.cs

@@ -1,11 +0,0 @@
-namespace Renci.SshNet.IntegrationTests
-{
-    class Program
-    {
-#if NETFRAMEWORK
-        private static void Main()
-        {
-        }
-#endif
-    }
-}

+ 2 - 1
test/Renci.SshNet.IntegrationTests/Renci.SshNet.IntegrationTests.csproj

@@ -1,11 +1,12 @@
 <Project Sdk="Microsoft.NET.Sdk">
 <Project Sdk="Microsoft.NET.Sdk">
 
 
   <PropertyGroup>
   <PropertyGroup>
-    <TargetFramework>net8.0</TargetFramework>
+    <TargetFrameworks>net48;net8.0</TargetFrameworks>
     <ImplicitUsings>enable</ImplicitUsings>
     <ImplicitUsings>enable</ImplicitUsings>
     <IsPackable>false</IsPackable>
     <IsPackable>false</IsPackable>
     <IsTestProject>true</IsTestProject>
     <IsTestProject>true</IsTestProject>
     <NoWarn>$(NoWarn);SYSLIB0021;SYSLIB1045;SYSLIB0014;IDE0220;IDE0010</NoWarn>
     <NoWarn>$(NoWarn);SYSLIB0021;SYSLIB1045;SYSLIB0014;IDE0220;IDE0010</NoWarn>
+    <AutoGenerateBindingRedirects>true</AutoGenerateBindingRedirects>
   </PropertyGroup>
   </PropertyGroup>
 
 
   <ItemGroup>
   <ItemGroup>

+ 1 - 1
test/Renci.SshNet.TestTools.OpenSSH/Renci.SshNet.TestTools.OpenSSH.csproj

@@ -1,6 +1,6 @@
 <Project Sdk="Microsoft.NET.Sdk">
 <Project Sdk="Microsoft.NET.Sdk">
   <PropertyGroup>
   <PropertyGroup>
-    <TargetFramework>net8.0</TargetFramework>
+    <TargetFramework>netstandard2.0</TargetFramework>
     <ImplicitUsings>enable</ImplicitUsings>
     <ImplicitUsings>enable</ImplicitUsings>
     <Nullable>enable</Nullable>
     <Nullable>enable</Nullable>
     <NoWarn>$(NoWarn);SYSLIB0021;SYSLIB1045</NoWarn>
     <NoWarn>$(NoWarn);SYSLIB0021;SYSLIB1045</NoWarn>

+ 1 - 1
test/Renci.SshNet.TestTools.OpenSSH/SshdConfig.cs

@@ -329,7 +329,7 @@ namespace Renci.SshNet.TestTools.OpenSSH
                     sshdConfig.KeyboardInteractiveAuthentication = ToBool(value);
                     sshdConfig.KeyboardInteractiveAuthentication = ToBool(value);
                     break;
                     break;
                 case "LogLevel":
                 case "LogLevel":
-                    sshdConfig.LogLevel = Enum.Parse<LogLevel>(value, ignoreCase: true);
+                    sshdConfig.LogLevel = (LogLevel)Enum.Parse(typeof(LogLevel), value, ignoreCase: true);
                     break;
                     break;
                 case "Subsystem":
                 case "Subsystem":
                     sshdConfig.Subsystems.Add(Subsystem.FromConfig(value));
                     sshdConfig.Subsystems.Add(Subsystem.FromConfig(value));