Sdílet prostřednictvím


MSTEST0008: Metoda TestInitialize by měla mít platné rozložení

Vlastnost Hodnota
ID pravidla MSTEST0008
Název Metoda TestInitialize by měla mít platné rozložení
Kategorie Využití
Oprava způsobující chybu nebo chybu způsobující chybu Nenarušující
Povoleno ve výchozím nastavení Ano
Výchozí závažnost Upozorňující
Představeno ve verzi 3.3.0
Existuje oprava kódu Ano

Příčina

Metoda označená [TestInitialize] pomocí by měla mít platné rozložení.

Popis pravidla

Metody označené [TestInitialize] pomocí následujícího rozložení by měly být platné:

  • mělo by to být public
  • nemělo by to být abstract
  • nemělo by to být async void
  • nemělo by to být static
  • neměla by se jednat o speciální metodu (finalizátor, operátor...).
  • nemělo by být obecné.
  • neměl by obsahovat žádný parametr.
  • návratový typ by měl být void, Task nebo ValueTask

Typ deklarující tyto metody by měl respektovat také následující pravidla:

  • Typ by měl být .class
  • Měl class by být public nebo internal (pokud testovací projekt používá [DiscoverInternals] atribut).
  • Nemělo class by to být static.
  • Pokud je class, sealed měla by být označena (nebo odvozeným atributem [TestClass] ).

Jak opravit porušení

Ujistěte se, že metoda odpovídá výše popsanému rozložení.

Kdy potlačit upozornění

Nepotlačujte upozornění na toto pravidlo. Pokud toto pravidlo ignorujete, instance s příznakem se buď přeskočí, nebo dojde k chybě za běhu.

Potlačte upozornění

Pokud chcete pouze potlačit jedno porušení, přidejte do zdrojového souboru direktivy preprocesoru, abyste pravidlo zakázali a znovu povolili.

#pragma warning disable MSTEST0008
// The code that's violating the rule is on this line.
#pragma warning restore MSTEST0008

Chcete-li pravidlo pro soubor, složku nebo projekt zakázat, nastavte jeho závažnost na none v konfiguračním souboru .

[*.{cs,vb}]
dotnet_diagnostic.MSTEST0008.severity = none

Další informace naleznete v tématu Jak potlačit upozornění analýzy kódu.