Condividi tramite


MSTEST0011: il metodo ClassCleanup deve avere un layout valido

Proprietà valore
ID regola MSTEST0011
Title Il metodo ClassCleanup deve avere un layout valido
Categoria Utilizzo
La correzione causa un'interruzione o meno Non causa un'interruzione
Abilitata per impostazione predefinita
Gravità predefinita Avviso
Introdotto nella versione 3.3.0
Esiste una correzione del codice

Causa

Un metodo contrassegnato con [ClassCleanup] deve avere un layout valido.

Descrizione regola

I metodi contrassegnati con [ClassCleanup] devono seguire il layout seguente per essere validi:

  • non può essere dichiarato in una classe generica senza che sia impostata la modalità InheritanceBehavior
  • deve essere public
  • deve essere static
  • non deve essere async void
  • non deve essere un metodo speciale (finalizzatore, operatore...).
  • non deve essere generico
  • non deve accettare alcun parametro
  • il tipo restituito deve essere void, Task o ValueTask
  • Il parametro dell'attributo InheritanceBehavior.BeforeEachDerivedClass deve essere specificato se la classe è abstract.
  • Il parametro dell'attributo InheritanceBehavior.BeforeEachDerivedClass non deve essere specificato se la classe è sealed.

Il tipo che dichiara questi metodi deve rispettare anche le regole seguenti:

  • Il tipo deve essere class.
  • class deve essere public o internal (se il progetto di test usa l'attributo [DiscoverInternals]).
  • class non deve essere static.
  • Se class è sealed, deve essere contrassegnato con [TestClass] (o un attributo derivato).
  • la classe non deve essere generica

Come correggere le violazioni

Assicurarsi che il metodo corrisponda al layout descritto in precedenza.

Quando eliminare gli avvisi

Non escludere un avviso da questa regola. Se si ignora questa regola, le istanze contrassegnate verranno ignorate o genereranno un errore di runtime.