Sdílet prostřednictvím


MSTEST0011: Metoda ClassCleanup by měla mít platné rozložení

Vlastnost Hodnota
ID pravidla MSTEST0011
Název Metoda ClassCleanup 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á [ClassCleanup] pomocí by měla mít platné rozložení.

Popis pravidla

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

  • nelze deklarovat v obecné třídě bez InheritanceBehavior nastavení režimu.
  • mělo by to být public
  • mělo by to být static
  • nemělo by to být async void
  • neměla by se jednat o speciální metodu (finalizátor, operátor...).
  • nemělo by být obecné.
  • Neměl by mít žádný parametr, ale od MSTest 3.8 může mít jeden parametr TestContext.
  • návratový typ by měl být void, Task nebo ValueTask
  • InheritanceBehavior.BeforeEachDerivedClass parametr atributu by měl být zadán, pokud je abstracttřída .
  • InheritanceBehavior.BeforeEachDerivedClass parametr atributu by neměl být zadán, pokud je sealedtřída .

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] ).
  • třída by neměla být obecná.

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 MSTEST0011
// The code that's violating the rule is on this line.
#pragma warning restore MSTEST0011

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.MSTEST0011.severity = none

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