MSTEST0017: アサーション引数は正しい順序で渡す必要があります
プロパティ | 値 |
---|---|
ルール ID | MSTEST0017 |
Title | アサーション引数は正しい順序で渡す必要があります |
カテゴリ | 使用法 |
修正が中断ありか中断なしか | なし |
既定で有効 | はい |
既定の重要度 | 情報 |
導入されたバージョン | 3.4.0 |
コード修正 はありますか | はい |
原因
このルールでは、Assert.AreEqual
、Assert.AreNotEqual
、Assert.AreSame
、または Assert.AreNotSame
の呼び出しが次の 1 つまたは複数のパターンに従っている場合に問題が発生します。
actual
引数が定数またはリテラル値であるactual
引数変数がexpected
、_expected
、またはExpected
で始まるexpected
またはnotExpected
引数変数がactual
で始まるactual
がローカル変数ではない
規則の説明
MSTest Assert.AreEqual
、Assert.AreNotEqual
、Assert.AreSame
、Assert.AreNotSame
では、最初の引数が予期される/予期しない値であり、2 番目の引数が実際の値であると想定されます。
予期される値と実際の値を間違った順序に設定しても、テストの結果 (成功/失敗であるはず) は変わりませんが、アサーション エラーには誤解を招く情報が含まれます。
違反の修正方法
actual
と expected
/notExpected
引数が正しい順序で渡されていることを確かめます。
どのようなときに警告を抑制するか
誤解を招く出力になるため、このルールの警告は抑制しないでください。
警告を抑制する
単一の違反を抑制するだけの場合は、プリプロセッサ ディレクティブをソース ファイルに追加して無効にしてから、ルールを再度有効にします。
#pragma warning disable MSTEST0017
// The code that's violating the rule is on this line.
#pragma warning restore MSTEST0017
ファイル、フォルダー、またはプロジェクトのルールを無効にするには、その重大度を 構成ファイルに none
に設定します。
[*.{cs,vb}]
dotnet_diagnostic.MSTEST0017.severity = none
詳細については、「コード分析の警告を抑制する方法」を参照してください。
GitHub で Microsoft と共同作業する
このコンテンツのソースは GitHub にあります。そこで、issue や pull request を作成および確認することもできます。 詳細については、共同作成者ガイドを参照してください。
.NET