mirror of
				https://github.com/Tyrrrz/CliFx.git
				synced 2025-10-25 15:19:17 +00:00 
			
		
		
		
	Refactor tests
This commit is contained in:
		| @@ -16,7 +16,7 @@ public class CancellationSpecs : SpecsBase | |||||||
|     } |     } | ||||||
|  |  | ||||||
|     [Fact] |     [Fact] | ||||||
|     public async Task Command_can_register_to_receive_a_cancellation_signal_from_the_console() |     public async Task Command_can_receive_a_cancellation_signal_from_the_console() | ||||||
|     { |     { | ||||||
|         // Arrange |         // Arrange | ||||||
|         var commandType = DynamicCommandBuilder.Compile( |         var commandType = DynamicCommandBuilder.Compile( | ||||||
|   | |||||||
| @@ -21,7 +21,7 @@ public class ConsoleSpecs : SpecsBase | |||||||
|     { |     { | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     [Fact] |     [Fact(Timeout = 15000)] | ||||||
|     public async Task Real_console_maps_directly_to_system_console() |     public async Task Real_console_maps_directly_to_system_console() | ||||||
|     { |     { | ||||||
|         // Can't verify our own console output, so using an |         // Can't verify our own console output, so using an | ||||||
|   | |||||||
| @@ -19,54 +19,35 @@ public class DirectivesSpecs : SpecsBase | |||||||
|     { |     { | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     [Fact] |     [Fact(Timeout = 15000)] | ||||||
|     public async Task Debug_directive_can_be_specified_to_interrupt_execution_until_a_debugger_is_attached() |     public async Task Debug_directive_can_be_specified_to_interrupt_execution_until_a_debugger_is_attached() | ||||||
|     { |     { | ||||||
|         // Arrange |         // Arrange | ||||||
|         var stdOutBuffer = new StringBuilder(); |         using var cts = new CancellationTokenSource(); | ||||||
|  |  | ||||||
|  |         // We can't actually attach a debugger, but we can ensure that the process is waiting for one | ||||||
|  |         void HandleStdOut(string line) | ||||||
|  |         { | ||||||
|  |             // Kill the process once it writes the output we expect | ||||||
|  |             if (line.Contains("Attach debugger to", StringComparison.OrdinalIgnoreCase)) | ||||||
|  |                 cts.Cancel(); | ||||||
|  |         } | ||||||
|  |  | ||||||
|         var command = Cli.Wrap("dotnet") |         var command = Cli.Wrap("dotnet") | ||||||
|             .WithArguments(a => a |             .WithArguments(a => a | ||||||
|                 .Add(Dummy.Program.Location) |                 .Add(Dummy.Program.Location) | ||||||
|                 .Add("[debug]") |                 .Add("[debug]") | ||||||
|             ) | stdOutBuffer; |             ) | HandleStdOut; | ||||||
|  |  | ||||||
|         // Act |         // Act & assert | ||||||
|         try |         try | ||||||
|         { |         { | ||||||
|             // This has a timeout just in case the execution hangs forever |             await command.ExecuteAsync(cts.Token); | ||||||
|             using var cts = new CancellationTokenSource(TimeSpan.FromSeconds(5)); |  | ||||||
|  |  | ||||||
|             var task = command.ExecuteAsync(cts.Token); |  | ||||||
|  |  | ||||||
|             // We can't attach a debugger programmatically, so the application |  | ||||||
|             // will hang indefinitely. |  | ||||||
|             // To work around it, we will wait until the application writes |  | ||||||
|             // something to the standard output and then kill it. |  | ||||||
|             while (true) |  | ||||||
|             { |  | ||||||
|                 if (stdOutBuffer.Length > 0) |  | ||||||
|                 { |  | ||||||
|                     cts.Cancel(); |  | ||||||
|                     break; |  | ||||||
|                 } |  | ||||||
|  |  | ||||||
|                 await Task.Delay(100, cts.Token); |  | ||||||
|             } |  | ||||||
|  |  | ||||||
|             await task; |  | ||||||
|         } |         } | ||||||
|         catch (OperationCanceledException) |         catch (OperationCanceledException ex) when (ex.CancellationToken == cts.Token) | ||||||
|         { |         { | ||||||
|             // This is expected |             // This means that the process was killed after it wrote the expected output | ||||||
|         } |         } | ||||||
|  |  | ||||||
|         var stdOut = stdOutBuffer.ToString(); |  | ||||||
|  |  | ||||||
|         // Assert |  | ||||||
|         stdOut.Should().Contain("Attach debugger to"); |  | ||||||
|  |  | ||||||
|         TestOutput.WriteLine(stdOut); |  | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     [Fact] |     [Fact] | ||||||
|   | |||||||
| @@ -241,7 +241,7 @@ public class EnvironmentSpecs : SpecsBase | |||||||
|         stdOut.Trim().Should().Be("bar"); |         stdOut.Trim().Should().Be("bar"); | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     [Fact] |     [Fact(Timeout = 15000)] | ||||||
|     public async Task Environment_variables_are_extracted_automatically() |     public async Task Environment_variables_are_extracted_automatically() | ||||||
|     { |     { | ||||||
|         // Ensures that the environment variables are properly obtained from |         // Ensures that the environment variables are properly obtained from | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user