- Roslyn Cookbook
- Manish Vasani
- 387字
- 2021-07-15 17:07:35
How to do it...
- Open UnitTests.cs in the CSharpAnalyzers.Test project in the Solution Explorer solution to view the default unit tests created for the default symbol analyzer (type names should not contain lowercase letters) for the template analyzer project.

- Navigate to Test | Windows | Test Window to open the Test Explorer window to view the unit tests in the project. Default analyzer project has two unit tests:
- TestMethod1: This tests the scenario where analyzer diagnostic does not fire on the test code and
- TestMethod2: This tests the scenario where analyzer diagnostic does fire on the test code.

Note that the unit test project contains unit tests for both the DiagnosticAnalyzer and CodeFixProvider. This chapter deals with analyzer testing only. We will expand on the unit tests for the CodeFixProvider later in this book.
- Run all the unit tests for the project by right-clicking Not Run tests node in the Test Explorer, executing the Run selected tests context menu command, and verify that the tests pass.
- Edit TestMethod1 so that the test code now has a type with lower-case letters:
[TestMethod]
public void TestMethod1()
{
var test = @"class Class1 { }";
VerifyCSharpDiagnostic(test);
}
- Right-click on TestMethod1 in the editor, execute the Run tests context menu command, and verify that the test now fails with the diagnostic mismatch assert - expected "0" actual "1":

- Edit TestMethod1 to now add an excepted diagnostic for the new test code:
var expected = new DiagnosticResult
{
Id = "CSharpAnalyzers",
Message = String.Format("Type name '{0}' contains lowercase letters", "Class1"),
Severity = DiagnosticSeverity.Warning,
Locations = new[] {
new DiagnosticResultLocation("Test0.cs", 11, 15)
}
};
VerifyCSharpDiagnostic(test, expected);
- Run the unit test again and note that the test still fails, but now it fails due to a difference in the location (column number) at which the diagnostic was reported.

- Edit the diagnostic location to use the correct expected column number and rerun the test - verify that the test passes now.
new DiagnosticResultLocation("Test0.cs", 11, 7)
- Edit TestMethod1 and change the test code to rename Class1 to CLASS1:
var test = @"class CLASS1 { }";
- Run the unit test again and verify that the test fails now due to a diagnostic mismatch assert - expected "1" actual "0".

- Edit TestMethod1 to remove the expected diagnostic and verify the test passes:
var test = @"class CLASS1 { }";
VerifyCSharpDiagnostic(test);
推薦閱讀
- The Complete Rust Programming Reference Guide
- C#高級編程(第10版) C# 6 & .NET Core 1.0 (.NET開發經典名著)
- Android和PHP開發最佳實踐(第2版)
- Java性能權威指南(第2版)
- 概率成形編碼調制技術理論及應用
- MySQL數據庫基礎實例教程(微課版)
- ASP.NET程序設計教程
- Babylon.js Essentials
- 0 bug:C/C++商用工程之道
- INSTANT Yii 1.1 Application Development Starter
- JavaScript應用開發實踐指南
- Python函數式編程(第2版)
- 快樂編程:青少年思維訓練
- Drupal 8 Development Cookbook(Second Edition)
- Python高性能編程(第2版)