mirror of
				https://github.com/spectreconsole/spectre.console.git
				synced 2025-10-25 15:19:23 +00:00 
			
		
		
		
	Simplify and make the code fix more robust
This commit is contained in:
		| @@ -104,6 +104,74 @@ class TestClass | ||||
|             .ConfigureAwait(false); | ||||
|     } | ||||
|  | ||||
|     [Fact] | ||||
|     public async Task SystemConsole_replaced_with_local_variable_AnsiConsole() | ||||
|     { | ||||
|         const string Source = @" | ||||
| using System; | ||||
| using Spectre.Console; | ||||
|  | ||||
| class TestClass  | ||||
| { | ||||
|     void TestMethod()  | ||||
|     { | ||||
|         IAnsiConsole ansiConsole = null; | ||||
|         Console.WriteLine(""Hello, World""); | ||||
|     } | ||||
| }"; | ||||
|  | ||||
|         const string FixedSource = @" | ||||
| using System; | ||||
| using Spectre.Console; | ||||
|  | ||||
| class TestClass  | ||||
| { | ||||
|     void TestMethod()  | ||||
|     { | ||||
|         IAnsiConsole ansiConsole = null; | ||||
|         ansiConsole.WriteLine(""Hello, World""); | ||||
|     } | ||||
| }"; | ||||
|  | ||||
|         await SpectreAnalyzerVerifier<UseSpectreInsteadOfSystemConsoleAnalyzer> | ||||
|             .VerifyCodeFixAsync(Source, _expectedDiagnostic.WithLocation(10, 9), FixedSource) | ||||
|             .ConfigureAwait(false); | ||||
|     } | ||||
|  | ||||
|     [Fact] | ||||
|     public async Task SystemConsole_not_replaced_with_local_variable_declared_after_the_call() | ||||
|     { | ||||
|         const string Source = @" | ||||
| using System; | ||||
| using Spectre.Console; | ||||
|  | ||||
| class TestClass  | ||||
| { | ||||
|     void TestMethod()  | ||||
|     { | ||||
|         Console.WriteLine(""Hello, World""); | ||||
|         IAnsiConsole ansiConsole; | ||||
|     } | ||||
| }"; | ||||
|  | ||||
|         const string FixedSource = @" | ||||
| using System; | ||||
| using Spectre.Console; | ||||
|  | ||||
| class TestClass  | ||||
| { | ||||
|     void TestMethod()  | ||||
|     { | ||||
|         AnsiConsole.WriteLine(""Hello, World""); | ||||
|         IAnsiConsole ansiConsole; | ||||
|     } | ||||
| }"; | ||||
|  | ||||
|         await SpectreAnalyzerVerifier<UseSpectreInsteadOfSystemConsoleAnalyzer> | ||||
|             .VerifyCodeFixAsync(Source, _expectedDiagnostic.WithLocation(9, 9), FixedSource) | ||||
|             .ConfigureAwait(false); | ||||
|     } | ||||
|  | ||||
|     [Fact] | ||||
|     public async Task SystemConsole_replaced_with_static_field_AnsiConsole() | ||||
|     { | ||||
| @@ -140,6 +208,108 @@ class TestClass | ||||
|             .ConfigureAwait(false); | ||||
|     } | ||||
|  | ||||
|     [Fact] | ||||
|     public async Task SystemConsole_replaced_with_AnsiConsole_when_field_is_not_static() | ||||
|     { | ||||
|         const string Source = @" | ||||
| using System; | ||||
| using Spectre.Console; | ||||
|  | ||||
| class TestClass  | ||||
| { | ||||
|     IAnsiConsole _ansiConsole; | ||||
|  | ||||
|     static void TestMethod()  | ||||
|     { | ||||
|         Console.WriteLine(""Hello, World""); | ||||
|     } | ||||
| }"; | ||||
|  | ||||
|         const string FixedSource = @" | ||||
| using System; | ||||
| using Spectre.Console; | ||||
|  | ||||
| class TestClass  | ||||
| { | ||||
|     IAnsiConsole _ansiConsole; | ||||
|  | ||||
|     static void TestMethod()  | ||||
|     { | ||||
|         AnsiConsole.WriteLine(""Hello, World""); | ||||
|     } | ||||
| }"; | ||||
|  | ||||
|         await SpectreAnalyzerVerifier<UseSpectreInsteadOfSystemConsoleAnalyzer> | ||||
|             .VerifyCodeFixAsync(Source, _expectedDiagnostic.WithLocation(11, 9), FixedSource) | ||||
|             .ConfigureAwait(false); | ||||
|     } | ||||
|  | ||||
|     [Fact] | ||||
|     public async Task SystemConsole_replaced_with_AnsiConsole_from_local_function_parameter() | ||||
|     { | ||||
|         const string Source = @" | ||||
| using System; | ||||
| using Spectre.Console; | ||||
|  | ||||
| class TestClass  | ||||
| { | ||||
|     static void TestMethod()  | ||||
|     { | ||||
|         static void LocalFunction(IAnsiConsole ansiConsole) => Console.WriteLine(""Hello, World""); | ||||
|     } | ||||
| }"; | ||||
|  | ||||
|         const string FixedSource = @" | ||||
| using System; | ||||
| using Spectre.Console; | ||||
|  | ||||
| class TestClass  | ||||
| { | ||||
|     static void TestMethod()  | ||||
|     { | ||||
|         static void LocalFunction(IAnsiConsole ansiConsole) => ansiConsole.WriteLine(""Hello, World""); | ||||
|     } | ||||
| }"; | ||||
|  | ||||
|         await SpectreAnalyzerVerifier<UseSpectreInsteadOfSystemConsoleAnalyzer> | ||||
|             .VerifyCodeFixAsync(Source, _expectedDiagnostic.WithLocation(9, 64), FixedSource) | ||||
|             .ConfigureAwait(false); | ||||
|     } | ||||
|  | ||||
|     [Fact] | ||||
|     public async Task SystemConsole_do_not_use_variable_from_parent_method_in_static_local_function() | ||||
|     { | ||||
|         const string Source = @" | ||||
| using System; | ||||
| using Spectre.Console; | ||||
|  | ||||
| class TestClass  | ||||
| { | ||||
|     static void TestMethod()  | ||||
|     { | ||||
|         IAnsiConsole ansiConsole = null; | ||||
|         static void LocalFunction() => Console.WriteLine(""Hello, World""); | ||||
|     } | ||||
| }"; | ||||
|  | ||||
|         const string FixedSource = @" | ||||
| using System; | ||||
| using Spectre.Console; | ||||
|  | ||||
| class TestClass  | ||||
| { | ||||
|     static void TestMethod()  | ||||
|     { | ||||
|         IAnsiConsole ansiConsole = null; | ||||
|         static void LocalFunction() => AnsiConsole.WriteLine(""Hello, World""); | ||||
|     } | ||||
| }"; | ||||
|  | ||||
|         await SpectreAnalyzerVerifier<UseSpectreInsteadOfSystemConsoleAnalyzer> | ||||
|             .VerifyCodeFixAsync(Source, _expectedDiagnostic.WithLocation(10, 40), FixedSource) | ||||
|             .ConfigureAwait(false); | ||||
|     } | ||||
|  | ||||
|     [Fact] | ||||
|     public async Task SystemConsole_replaced_with_AnsiConsole_in_top_level_statements() | ||||
|     { | ||||
|   | ||||
		Reference in New Issue
	
	Block a user