MSTEST0009: metoda TestCleanup powinna mieć prawidłowy układ
Właściwości | Wartość |
---|---|
Identyfikator reguły | MSTEST0009 |
Tytuł | Metoda TestCleanup powinna mieć prawidłowy układ |
Kategoria | Użycie |
Poprawka powodująca niezgodność lub niezgodność | Niezgodność |
Domyślnie włączone | Tak |
Ważność domyślna | Ostrzeżenie |
Wprowadzone w wersji | 3.3.0 |
czy istnieje poprawka kodu | Tak |
Przyczyna
Metoda oznaczona elementem [TestCleanup]
powinna mieć prawidłowy układ.
Opis reguły
Metody oznaczone za pomocą powinny być zgodne z [TestCleanup]
następującym układem, aby były prawidłowe:
- powinna być
public
- nie powinien być
abstract
- nie powinien być
async void
- nie powinien być
static
- nie powinna być metodą specjalną (finalizer, operator...).
- nie powinien być ogólny
- nie powinien przyjmować żadnego parametru
- zwracany typ powinien mieć
void
wartość ,Task
lubValueTask
Typ deklarujący te metody powinien również przestrzegać następujących reguł:
- Typ powinien mieć wartość
class
. - Element
class
powinien mieć wartośćpublic
lubinternal
(jeśli projekt testowy używa atrybutu[DiscoverInternals]
). - Wartość
class
nie powinna być .static
- Jeśli element
class
masealed
wartość , powinien zostać oznaczony znakiem[TestClass]
(lub atrybutem pochodnym).
Jak naprawić naruszenia
Upewnij się, że metoda jest zgodna z układem opisanym powyżej.
Kiedy pomijać ostrzeżenia
Nie pomijaj ostrzeżeń dla tej reguły. Jeśli zignorujesz tę regułę, oflagowane wystąpienia zostaną pominięte lub spowodują błąd środowiska uruchomieniowego.
Pomijanie ostrzeżenia
Jeśli chcesz po prostu pominąć pojedyncze naruszenie, dodaj dyrektywy preprocesora do pliku źródłowego, aby wyłączyć, a następnie ponownie włączyć regułę.
#pragma warning disable MSTEST0009
// The code that's violating the rule is on this line.
#pragma warning restore MSTEST0009
Aby wyłączyć regułę dla pliku, folderu lub projektu, ustaw jego ważność na none
w pliku konfiguracji .
[*.{cs,vb}]
dotnet_diagnostic.MSTEST0009.severity = none
Aby uzyskać więcej informacji, zobacz Jak pominąć ostrzeżenia analizy kodu.