| 属性 | 值 |
|---|---|
| 规则 ID | MSTEST0020 |
| 标题 | 首选构造函数而非 TestInitialize 方法 |
| 类别 | 设计 |
| 修复是中断修复还是非中断修复 | 非中断 |
| 默认已启用 | 否 |
| 默认严重性 | 信息 |
| 引入版本 | 3.4.0 |
| 是否存在代码修补程序 | 是 |
原因
当存在 void [TestInitialize] 方法时,此规则引发诊断。
规则说明
依赖构造函数进行非异步初始化通常更好,因为然后可依赖 readonly 并在开发测试时获得更好的编译器反馈。 处理启用了可为空的上下文时尤其如此。
如何解决冲突
通过构造函数替换返回 [TestInitialize] 的 void。
何时禁止显示警告
如果你决定选择遵循此规则,则通常不希望禁止显示此规则的警告。
注释
此规则是可选的。 即使在使用 <MSTestAnalysisMode>All</MSTestAnalysisMode> 时也不会启用它。 有关 MSTestAnalysisMode的详细信息,请参阅 MSTest 代码分析。
抑制警告
如果只想抑制单个冲突,请将预处理器指令添加到源文件以禁用该规则,然后重新启用该规则。
#pragma warning disable MSTEST0020
// The code that's violating the rule is on this line.
#pragma warning restore MSTEST0020
若要对文件、文件夹或项目禁用该规则,请在配置文件中将其严重性设置为 none。
[*.{cs,vb}]
dotnet_diagnostic.MSTEST0020.severity = none
有关详细信息,请参阅如何禁止显示代码分析警告。