From a9b96d7356ea085ce1ac0502e679f5dd11f22e5c Mon Sep 17 00:00:00 2001 From: Tom Deseyn Date: Mon, 27 Feb 2023 16:38:36 +0100 Subject: [PATCH] DotNetHelper: fix IsMonoRuntime being initialized before extracting the sdk. --- .../DotNetHelper.cs | 7 +++---- 1 file changed, 3 insertions(+), 4 deletions(-) diff --git a/src/SourceBuild/tarball/content/test/Microsoft.DotNet.SourceBuild.SmokeTests/DotNetHelper.cs b/src/SourceBuild/tarball/content/test/Microsoft.DotNet.SourceBuild.SmokeTests/DotNetHelper.cs index ff1071e2ee92..80ff2e29ea60 100644 --- a/src/SourceBuild/tarball/content/test/Microsoft.DotNet.SourceBuild.SmokeTests/DotNetHelper.cs +++ b/src/SourceBuild/tarball/content/test/Microsoft.DotNet.SourceBuild.SmokeTests/DotNetHelper.cs @@ -14,13 +14,13 @@ internal class DotNetHelper { private static readonly object s_lockObj = new(); - private static bool IsMonoRuntime { get; } = DetermineIsMonoRuntime(); public static string DotNetPath { get; } = Path.Combine(Config.DotNetDirectory, "dotnet"); public static string LogsDirectory { get; } = Path.Combine(Directory.GetCurrentDirectory(), "logs"); public static string PackagesDirectory { get; } = Path.Combine(Directory.GetCurrentDirectory(), "packages"); public static string ProjectsDirectory { get; } = Path.Combine(Directory.GetCurrentDirectory(), $"projects-{DateTime.Now:yyyyMMddHHmmssffff}"); private ITestOutputHelper OutputHelper { get; } + private bool IsMonoRuntime { get; } public DotNetHelper(ITestOutputHelper outputHelper) { @@ -38,6 +38,7 @@ public DotNetHelper(ITestOutputHelper outputHelper) Directory.CreateDirectory(Config.DotNetDirectory); ExecuteHelper.ExecuteProcessValidateExitCode("tar", $"xzf {Config.SdkTarballPath} -C {Config.DotNetDirectory}", outputHelper); } + IsMonoRuntime = DetermineIsMonoRuntime(Config.DotNetDirectory); if (!Directory.Exists(ProjectsDirectory)) { @@ -234,10 +235,8 @@ private static string GetBinLogOption(string projectName, string command, string return $"/bl:{Path.Combine(LogsDirectory, $"{fileName}.binlog")}"; } - private static bool DetermineIsMonoRuntime() + private static bool DetermineIsMonoRuntime(string dotnetRoot) { - string dotnetRoot = Config.DotNetDirectory; - string sharedFrameworkRoot = Path.Combine(dotnetRoot, "shared", "Microsoft.NETCore.App"); if (!Directory.Exists(sharedFrameworkRoot)) {