diff --git a/src/Microsoft.DotNet.Configurer/DotnetFirstRunConfiguration.cs b/src/Microsoft.DotNet.Configurer/DotnetFirstRunConfiguration.cs new file mode 100644 index 000000000..b959c7c41 --- /dev/null +++ b/src/Microsoft.DotNet.Configurer/DotnetFirstRunConfiguration.cs @@ -0,0 +1,24 @@ +// Copyright (c) .NET Foundation and contributors. All rights reserved. +// Licensed under the MIT license. See LICENSE file in the project root for full license information. + +namespace Microsoft.DotNet.Configurer +{ + public class DotnetFirstRunConfiguration + { + public bool GenerateAspNetCertificate { get; } + + public bool PrintTelemetryMessage { get; } + + public bool SkipFirstRunExperience { get; } + + public DotnetFirstRunConfiguration( + bool generateAspNetCertificate, + bool printTelemetryMessage, + bool skipFirstRunExperience) + { + GenerateAspNetCertificate = generateAspNetCertificate; + PrintTelemetryMessage = printTelemetryMessage; + SkipFirstRunExperience = skipFirstRunExperience; + } + } +} \ No newline at end of file diff --git a/src/Microsoft.DotNet.Configurer/DotnetFirstTimeUseConfigurer.cs b/src/Microsoft.DotNet.Configurer/DotnetFirstTimeUseConfigurer.cs index 2cb502256..94478909b 100644 --- a/src/Microsoft.DotNet.Configurer/DotnetFirstTimeUseConfigurer.cs +++ b/src/Microsoft.DotNet.Configurer/DotnetFirstTimeUseConfigurer.cs @@ -12,7 +12,7 @@ namespace Microsoft.DotNet.Configurer public class DotnetFirstTimeUseConfigurer { private IReporter _reporter; - private IEnvironmentProvider _environmentProvider; + private DotnetFirstRunConfiguration _dotnetFirstRunConfiguration; private INuGetCachePrimer _nugetCachePrimer; private INuGetCacheSentinel _nugetCacheSentinel; private IFirstTimeUseNoticeSentinel _firstTimeUseNoticeSentinel; @@ -29,7 +29,7 @@ namespace Microsoft.DotNet.Configurer IAspNetCertificateSentinel aspNetCertificateSentinel, IAspNetCoreCertificateGenerator aspNetCoreCertificateGenerator, IFileSentinel toolPathSentinel, - IEnvironmentProvider environmentProvider, + DotnetFirstRunConfiguration dotnetFirstRunConfiguration, IReporter reporter, string cliFallbackFolderPath, IEnvironmentPath pathAdder) @@ -40,7 +40,7 @@ namespace Microsoft.DotNet.Configurer _aspNetCertificateSentinel = aspNetCertificateSentinel; _aspNetCoreCertificateGenerator = aspNetCoreCertificateGenerator; _toolPathSentinel = toolPathSentinel; - _environmentProvider = environmentProvider; + _dotnetFirstRunConfiguration = dotnetFirstRunConfiguration; _reporter = reporter; _cliFallbackFolderPath = cliFallbackFolderPath; _pathAdder = pathAdder ?? throw new ArgumentNullException(nameof(pathAdder)); @@ -93,11 +93,8 @@ namespace Microsoft.DotNet.Configurer #if EXCLUDE_ASPNETCORE return false; #else - var generateAspNetCertificate = - _environmentProvider.GetEnvironmentVariableAsBool("DOTNET_GENERATE_ASPNET_CERTIFICATE", true); - return ShouldRunFirstRunExperience() && - generateAspNetCertificate && + _dotnetFirstRunConfiguration.GenerateAspNetCertificate && !_aspNetCertificateSentinel.Exists(); #endif } @@ -116,11 +113,8 @@ namespace Microsoft.DotNet.Configurer private bool ShouldPrintFirstTimeUseNotice() { - var showFirstTimeUseNotice = - _environmentProvider.GetEnvironmentVariableAsBool("DOTNET_PRINT_TELEMETRY_MESSAGE", true); - return ShouldRunFirstRunExperience() && - showFirstTimeUseNotice && + _dotnetFirstRunConfiguration.PrintTelemetryMessage && !_firstTimeUseNoticeSentinel.Exists(); } @@ -157,10 +151,7 @@ namespace Microsoft.DotNet.Configurer private bool ShouldRunFirstRunExperience() { - var skipFirstTimeExperience = - _environmentProvider.GetEnvironmentVariableAsBool("DOTNET_SKIP_FIRST_TIME_EXPERIENCE", false); - - return !skipFirstTimeExperience; + return !_dotnetFirstRunConfiguration.SkipFirstRunExperience; } } } diff --git a/src/dotnet/Program.cs b/src/dotnet/Program.cs index ce08bcb56..2e9dafea5 100644 --- a/src/dotnet/Program.cs +++ b/src/dotnet/Program.cs @@ -141,6 +141,15 @@ namespace Microsoft.DotNet.Cli command = "help"; } + var environmentProvider = new EnvironmentProvider(); + + bool generateAspNetCertificate = + environmentProvider.GetEnvironmentVariableAsBool("DOTNET_GENERATE_ASPNET_CERTIFICATE", true); + bool printTelemetryMessage = + environmentProvider.GetEnvironmentVariableAsBool("DOTNET_PRINT_TELEMETRY_MESSAGE", true); + bool skipFirstRunExperience = + environmentProvider.GetEnvironmentVariableAsBool("DOTNET_SKIP_FIRST_TIME_EXPERIENCE", false); + topLevelCommandParserResult = new TopLevelCommandParserResult(command); var hasSuperUserAccess = false; if (IsDotnetBeingInvokedFromNativeInstaller(topLevelCommandParserResult)) @@ -149,15 +158,26 @@ namespace Microsoft.DotNet.Cli firstTimeUseNoticeSentinel = new NoOpFirstTimeUseNoticeSentinel(); toolPathSentinel = new NoOpFileSentinel(exists: false); hasSuperUserAccess = true; + + // When running through a native installer, we want the cache expansion to happen, so + // we need to override this. + skipFirstRunExperience = false; } + var dotnetFirstRunConfiguration = new DotnetFirstRunConfiguration( + generateAspNetCertificate, + printTelemetryMessage, + skipFirstRunExperience); + ConfigureDotNetForFirstTimeUse( nugetCacheSentinel, firstTimeUseNoticeSentinel, aspNetCertificateSentinel, toolPathSentinel, cliFallbackFolderPathCalculator, - hasSuperUserAccess); + hasSuperUserAccess, + dotnetFirstRunConfiguration, + environmentProvider); break; } @@ -222,15 +242,17 @@ namespace Microsoft.DotNet.Cli IAspNetCertificateSentinel aspNetCertificateSentinel, IFileSentinel toolPathSentinel, CliFolderPathCalculator cliFolderPathCalculator, - bool hasSuperUserAccess) + bool hasSuperUserAccess, + DotnetFirstRunConfiguration dotnetFirstRunConfiguration, + IEnvironmentProvider environmentProvider) { - var environmentProvider = new EnvironmentProvider(); - using (PerfTrace.Current.CaptureTiming()) { var nugetPackagesArchiver = new NuGetPackagesArchiver(); - var environmentPath = - EnvironmentPathFactory.CreateEnvironmentPath(cliFolderPathCalculator, hasSuperUserAccess, environmentProvider); + var environmentPath = EnvironmentPathFactory.CreateEnvironmentPath( + cliFolderPathCalculator, + hasSuperUserAccess, + environmentProvider); var commandFactory = new DotNetCommandFactory(alwaysRunOutOfProc: true); var nugetCachePrimer = new NuGetCachePrimer( nugetPackagesArchiver, @@ -244,7 +266,7 @@ namespace Microsoft.DotNet.Cli aspNetCertificateSentinel, aspnetCertificateGenerator, toolPathSentinel, - environmentProvider, + dotnetFirstRunConfiguration, Reporter.Output, cliFolderPathCalculator.CliFallbackFolderPath, environmentPath); diff --git a/test/Microsoft.DotNet.Configurer.UnitTests/GivenADotnetFirstTimeUseConfigurer.cs b/test/Microsoft.DotNet.Configurer.UnitTests/GivenADotnetFirstTimeUseConfigurer.cs index 115acacd7..37036602d 100644 --- a/test/Microsoft.DotNet.Configurer.UnitTests/GivenADotnetFirstTimeUseConfigurer.cs +++ b/test/Microsoft.DotNet.Configurer.UnitTests/GivenADotnetFirstTimeUseConfigurer.cs @@ -21,7 +21,6 @@ namespace Microsoft.DotNet.Configurer.UnitTests private Mock _aspNetCertificateSentinelMock; private Mock _aspNetCoreCertificateGeneratorMock; private Mock _toolPathSentinelMock; - private Mock _environmentProviderMock; private Mock _reporterMock; private Mock _pathAdderMock; @@ -33,16 +32,8 @@ namespace Microsoft.DotNet.Configurer.UnitTests _aspNetCertificateSentinelMock = new Mock(); _aspNetCoreCertificateGeneratorMock = new Mock(); _toolPathSentinelMock = new Mock(); - _environmentProviderMock = new Mock(); _reporterMock = new Mock(); _pathAdderMock = new Mock(); - - _environmentProviderMock - .Setup(e => e.GetEnvironmentVariableAsBool("DOTNET_SKIP_FIRST_TIME_EXPERIENCE", false)) - .Returns(false); - _environmentProviderMock - .Setup(e => e.GetEnvironmentVariableAsBool("DOTNET_PRINT_TELEMETRY_MESSAGE", true)) - .Returns(true); } [Fact] @@ -57,7 +48,12 @@ namespace Microsoft.DotNet.Configurer.UnitTests _aspNetCertificateSentinelMock.Object, _aspNetCoreCertificateGeneratorMock.Object, _toolPathSentinelMock.Object, - _environmentProviderMock.Object, + new DotnetFirstRunConfiguration + ( + generateAspNetCertificate: true, + printTelemetryMessage: true, + skipFirstRunExperience: false + ), _reporterMock.Object, CliFallbackFolderPath, _pathAdderMock.Object); @@ -72,9 +68,6 @@ namespace Microsoft.DotNet.Configurer.UnitTests public void It_does_not_print_the_first_time_use_notice_when_the_user_has_set_the_DOTNET_SKIP_FIRST_TIME_EXPERIENCE_environemnt_variable() { _firstTimeUseNoticeSentinelMock.Setup(n => n.Exists()).Returns(false); - _environmentProviderMock - .Setup(e => e.GetEnvironmentVariableAsBool("DOTNET_SKIP_FIRST_TIME_EXPERIENCE", false)) - .Returns(true); var dotnetFirstTimeUseConfigurer = new DotnetFirstTimeUseConfigurer( _nugetCachePrimerMock.Object, @@ -83,7 +76,12 @@ namespace Microsoft.DotNet.Configurer.UnitTests _aspNetCertificateSentinelMock.Object, _aspNetCoreCertificateGeneratorMock.Object, _toolPathSentinelMock.Object, - _environmentProviderMock.Object, + new DotnetFirstRunConfiguration + ( + generateAspNetCertificate: true, + printTelemetryMessage: true, + skipFirstRunExperience: true + ), _reporterMock.Object, CliFallbackFolderPath, _pathAdderMock.Object); @@ -98,9 +96,6 @@ namespace Microsoft.DotNet.Configurer.UnitTests public void It_does_not_print_the_first_time_use_notice_when_the_user_has_set_the_DOTNET_PRINT_TELEMETRY_MESSAGE_environemnt_variable() { _firstTimeUseNoticeSentinelMock.Setup(n => n.Exists()).Returns(false); - _environmentProviderMock - .Setup(e => e.GetEnvironmentVariableAsBool("DOTNET_PRINT_TELEMETRY_MESSAGE", true)) - .Returns(false); var dotnetFirstTimeUseConfigurer = new DotnetFirstTimeUseConfigurer( _nugetCachePrimerMock.Object, @@ -109,7 +104,12 @@ namespace Microsoft.DotNet.Configurer.UnitTests _aspNetCertificateSentinelMock.Object, _aspNetCoreCertificateGeneratorMock.Object, _toolPathSentinelMock.Object, - _environmentProviderMock.Object, + new DotnetFirstRunConfiguration + ( + generateAspNetCertificate: true, + printTelemetryMessage: false, + skipFirstRunExperience: false + ), _reporterMock.Object, CliFallbackFolderPath, _pathAdderMock.Object); @@ -132,7 +132,12 @@ namespace Microsoft.DotNet.Configurer.UnitTests _aspNetCertificateSentinelMock.Object, _aspNetCoreCertificateGeneratorMock.Object, _toolPathSentinelMock.Object, - _environmentProviderMock.Object, + new DotnetFirstRunConfiguration + ( + generateAspNetCertificate: true, + printTelemetryMessage: true, + skipFirstRunExperience: false + ), _reporterMock.Object, CliFallbackFolderPath, _pathAdderMock.Object); @@ -155,7 +160,12 @@ namespace Microsoft.DotNet.Configurer.UnitTests _aspNetCertificateSentinelMock.Object, _aspNetCoreCertificateGeneratorMock.Object, _toolPathSentinelMock.Object, - _environmentProviderMock.Object, + new DotnetFirstRunConfiguration + ( + generateAspNetCertificate: true, + printTelemetryMessage: true, + skipFirstRunExperience: false + ), _reporterMock.Object, CliFallbackFolderPath, _pathAdderMock.Object); @@ -177,7 +187,12 @@ namespace Microsoft.DotNet.Configurer.UnitTests _aspNetCertificateSentinelMock.Object, _aspNetCoreCertificateGeneratorMock.Object, _toolPathSentinelMock.Object, - _environmentProviderMock.Object, + new DotnetFirstRunConfiguration + ( + generateAspNetCertificate: true, + printTelemetryMessage: true, + skipFirstRunExperience: false + ), _reporterMock.Object, CliFallbackFolderPath, _pathAdderMock.Object); @@ -199,7 +214,12 @@ namespace Microsoft.DotNet.Configurer.UnitTests _aspNetCertificateSentinelMock.Object, _aspNetCoreCertificateGeneratorMock.Object, _toolPathSentinelMock.Object, - _environmentProviderMock.Object, + new DotnetFirstRunConfiguration + ( + generateAspNetCertificate: true, + printTelemetryMessage: true, + skipFirstRunExperience: false + ), _reporterMock.Object, CliFallbackFolderPath, _pathAdderMock.Object); @@ -210,12 +230,9 @@ namespace Microsoft.DotNet.Configurer.UnitTests } [Fact] - public void It_does_not_prime_the_cache_if_the_sentinel_exists_but_the_user_has_set_the_DOTNET_SKIP_FIRST_TIME_EXPERIENCE_environemnt_variable() + public void It_does_not_prime_the_cache_if_the_sentinel_does_not_exist_but_the_user_has_set_the_DOTNET_SKIP_FIRST_TIME_EXPERIENCE_environment_variable() { _nugetCacheSentinelMock.Setup(n => n.Exists()).Returns(false); - _environmentProviderMock - .Setup(e => e.GetEnvironmentVariableAsBool("DOTNET_SKIP_FIRST_TIME_EXPERIENCE", false)) - .Returns(true); var dotnetFirstTimeUseConfigurer = new DotnetFirstTimeUseConfigurer( _nugetCachePrimerMock.Object, @@ -224,7 +241,12 @@ namespace Microsoft.DotNet.Configurer.UnitTests _aspNetCertificateSentinelMock.Object, _aspNetCoreCertificateGeneratorMock.Object, _toolPathSentinelMock.Object, - _environmentProviderMock.Object, + new DotnetFirstRunConfiguration + ( + generateAspNetCertificate: true, + printTelemetryMessage: true, + skipFirstRunExperience: true + ), _reporterMock.Object, CliFallbackFolderPath, _pathAdderMock.Object); @@ -246,7 +268,12 @@ namespace Microsoft.DotNet.Configurer.UnitTests _aspNetCertificateSentinelMock.Object, _aspNetCoreCertificateGeneratorMock.Object, _toolPathSentinelMock.Object, - _environmentProviderMock.Object, + new DotnetFirstRunConfiguration + ( + generateAspNetCertificate: true, + printTelemetryMessage: true, + skipFirstRunExperience: false + ), _reporterMock.Object, CliFallbackFolderPath, _pathAdderMock.Object); @@ -269,7 +296,12 @@ namespace Microsoft.DotNet.Configurer.UnitTests _aspNetCertificateSentinelMock.Object, _aspNetCoreCertificateGeneratorMock.Object, _toolPathSentinelMock.Object, - _environmentProviderMock.Object, + new DotnetFirstRunConfiguration + ( + generateAspNetCertificate: true, + printTelemetryMessage: true, + skipFirstRunExperience: false + ), _reporterMock.Object, CliFallbackFolderPath, _pathAdderMock.Object); @@ -295,7 +327,12 @@ namespace Microsoft.DotNet.Configurer.UnitTests _aspNetCertificateSentinelMock.Object, _aspNetCoreCertificateGeneratorMock.Object, _toolPathSentinelMock.Object, - _environmentProviderMock.Object, + new DotnetFirstRunConfiguration + ( + generateAspNetCertificate: true, + printTelemetryMessage: true, + skipFirstRunExperience: false + ), _reporterMock.Object, CliFallbackFolderPath, _pathAdderMock.Object); @@ -322,7 +359,12 @@ namespace Microsoft.DotNet.Configurer.UnitTests _aspNetCertificateSentinelMock.Object, _aspNetCoreCertificateGeneratorMock.Object, _toolPathSentinelMock.Object, - _environmentProviderMock.Object, + new DotnetFirstRunConfiguration + ( + generateAspNetCertificate: true, + printTelemetryMessage: true, + skipFirstRunExperience: false + ), _reporterMock.Object, CliFallbackFolderPath, _pathAdderMock.Object); @@ -345,7 +387,12 @@ namespace Microsoft.DotNet.Configurer.UnitTests _aspNetCertificateSentinelMock.Object, _aspNetCoreCertificateGeneratorMock.Object, _toolPathSentinelMock.Object, - _environmentProviderMock.Object, + new DotnetFirstRunConfiguration + ( + generateAspNetCertificate: true, + printTelemetryMessage: true, + skipFirstRunExperience: false + ), _reporterMock.Object, CliFallbackFolderPath, _pathAdderMock.Object); @@ -368,7 +415,12 @@ namespace Microsoft.DotNet.Configurer.UnitTests _aspNetCertificateSentinelMock.Object, _aspNetCoreCertificateGeneratorMock.Object, _toolPathSentinelMock.Object, - _environmentProviderMock.Object, + new DotnetFirstRunConfiguration + ( + generateAspNetCertificate: true, + printTelemetryMessage: true, + skipFirstRunExperience: false + ), _reporterMock.Object, CliFallbackFolderPath, _pathAdderMock.Object); @@ -398,7 +450,12 @@ namespace Microsoft.DotNet.Configurer.UnitTests _aspNetCertificateSentinelMock.Object, _aspNetCoreCertificateGeneratorMock.Object, _toolPathSentinelMock.Object, - _environmentProviderMock.Object, + new DotnetFirstRunConfiguration + ( + generateAspNetCertificate: true, + printTelemetryMessage: true, + skipFirstRunExperience: false + ), _reporterMock.Object, CliFallbackFolderPath, _pathAdderMock.Object); @@ -420,7 +477,12 @@ namespace Microsoft.DotNet.Configurer.UnitTests _aspNetCertificateSentinelMock.Object, _aspNetCoreCertificateGeneratorMock.Object, _toolPathSentinelMock.Object, - _environmentProviderMock.Object, + new DotnetFirstRunConfiguration + ( + generateAspNetCertificate: true, + printTelemetryMessage: true, + skipFirstRunExperience: false + ), _reporterMock.Object, CliFallbackFolderPath, _pathAdderMock.Object); @@ -435,9 +497,6 @@ namespace Microsoft.DotNet.Configurer.UnitTests public void It_does_not_generate_the_aspnet_https_development_certificate_when_the_user_has_set_the_DOTNET_SKIP_FIRST_TIME_EXPERIENCE_environment_variable() { _aspNetCertificateSentinelMock.Setup(n => n.Exists()).Returns(false); - _environmentProviderMock - .Setup(e => e.GetEnvironmentVariableAsBool("DOTNET_SKIP_FIRST_TIME_EXPERIENCE", false)) - .Returns(true); var dotnetFirstTimeUseConfigurer = new DotnetFirstTimeUseConfigurer( _nugetCachePrimerMock.Object, @@ -446,7 +505,12 @@ namespace Microsoft.DotNet.Configurer.UnitTests _aspNetCertificateSentinelMock.Object, _aspNetCoreCertificateGeneratorMock.Object, _toolPathSentinelMock.Object, - _environmentProviderMock.Object, + new DotnetFirstRunConfiguration + ( + generateAspNetCertificate: true, + printTelemetryMessage: true, + skipFirstRunExperience: true + ), _reporterMock.Object, CliFallbackFolderPath, _pathAdderMock.Object); @@ -461,9 +525,6 @@ namespace Microsoft.DotNet.Configurer.UnitTests public void It_does_not_generate_the_aspnet_https_development_certificate_when_the_user_has_set_the_DOTNET_GENERATE_ASPNET_CERTIFICATE_environment_variable() { _aspNetCertificateSentinelMock.Setup(n => n.Exists()).Returns(false); - _environmentProviderMock - .Setup(e => e.GetEnvironmentVariableAsBool("DOTNET_GENERATE_ASPNET_CERTIFICATE", true)) - .Returns(false); var dotnetFirstTimeUseConfigurer = new DotnetFirstTimeUseConfigurer( _nugetCachePrimerMock.Object, @@ -472,7 +533,12 @@ namespace Microsoft.DotNet.Configurer.UnitTests _aspNetCertificateSentinelMock.Object, _aspNetCoreCertificateGeneratorMock.Object, _toolPathSentinelMock.Object, - _environmentProviderMock.Object, + new DotnetFirstRunConfiguration + ( + generateAspNetCertificate: false, + printTelemetryMessage: true, + skipFirstRunExperience: false + ), _reporterMock.Object, CliFallbackFolderPath, _pathAdderMock.Object); @@ -487,8 +553,6 @@ namespace Microsoft.DotNet.Configurer.UnitTests public void It_generates_the_aspnet_https_development_certificate_if_the_sentinel_does_not_exist() { _aspNetCertificateSentinelMock.Setup(n => n.Exists()).Returns(false); - _environmentProviderMock.Setup(e => e.GetEnvironmentVariableAsBool("DOTNET_GENERATE_ASPNET_CERTIFICATE", true)) - .Returns(true); var dotnetFirstTimeUseConfigurer = new DotnetFirstTimeUseConfigurer( _nugetCachePrimerMock.Object, @@ -497,7 +561,12 @@ namespace Microsoft.DotNet.Configurer.UnitTests _aspNetCertificateSentinelMock.Object, _aspNetCoreCertificateGeneratorMock.Object, _toolPathSentinelMock.Object, - _environmentProviderMock.Object, + new DotnetFirstRunConfiguration + ( + generateAspNetCertificate: true, + printTelemetryMessage: true, + skipFirstRunExperience: false + ), _reporterMock.Object, CliFallbackFolderPath, _pathAdderMock.Object); @@ -520,7 +589,12 @@ namespace Microsoft.DotNet.Configurer.UnitTests _aspNetCertificateSentinelMock.Object, _aspNetCoreCertificateGeneratorMock.Object, _toolPathSentinelMock.Object, - _environmentProviderMock.Object, + new DotnetFirstRunConfiguration + ( + generateAspNetCertificate: true, + printTelemetryMessage: true, + skipFirstRunExperience: false + ), _reporterMock.Object, CliFallbackFolderPath, _pathAdderMock.Object); @@ -533,10 +607,6 @@ namespace Microsoft.DotNet.Configurer.UnitTests [Fact] public void It_does_not_add_the_tool_path_to_the_environment_if_the_first_run_experience_is_skipped() { - _environmentProviderMock - .Setup(e => e.GetEnvironmentVariableAsBool("DOTNET_SKIP_FIRST_TIME_EXPERIENCE", false)) - .Returns(true); - var dotnetFirstTimeUseConfigurer = new DotnetFirstTimeUseConfigurer( _nugetCachePrimerMock.Object, _nugetCacheSentinelMock.Object, @@ -544,7 +614,12 @@ namespace Microsoft.DotNet.Configurer.UnitTests _aspNetCertificateSentinelMock.Object, _aspNetCoreCertificateGeneratorMock.Object, _toolPathSentinelMock.Object, - _environmentProviderMock.Object, + new DotnetFirstRunConfiguration + ( + generateAspNetCertificate: true, + printTelemetryMessage: true, + skipFirstRunExperience: true + ), _reporterMock.Object, CliFallbackFolderPath, _pathAdderMock.Object); diff --git a/test/Microsoft.DotNet.TestFramework/Microsoft.DotNet.TestFramework.csproj b/test/Microsoft.DotNet.TestFramework/Microsoft.DotNet.TestFramework.csproj index 59b36f03c..8c85a02fe 100644 --- a/test/Microsoft.DotNet.TestFramework/Microsoft.DotNet.TestFramework.csproj +++ b/test/Microsoft.DotNet.TestFramework/Microsoft.DotNet.TestFramework.csproj @@ -13,9 +13,5 @@ - - - - - + \ No newline at end of file