MSTEST0024: TestContext nicht in einem statischen Member speichern
Eigenschaft | Wert |
---|---|
Regel-ID | MSTEST0024 |
Titel | TestContext nicht in einem statischen Member speichern |
Kategorie | Verwendung |
Fix führt oder führt nicht zur Unterbrechung | Nicht unterbrechend |
Standardmäßig aktiviert | Ja |
Standardschweregrad | Info |
Eingeführt in Version | 3.4.0 |
Gibt es eine Codekorrektur | No |
Ursache
Diese Regel löst eine Diagnose aus, wenn eine Zuweisung zu einem static
-Member eines TestContext
-Parameters erfolgt.
Regelbeschreibung
Der TestContext
-Parameter, der an jede Initialisierungsmethode ([AssemblyInitialize]
oder [ClassInitialize]
) übergeben wird, ist spezifisch für den aktuellen Kontext und wird nicht bei jeder Testausführung aktualisiert. Wenn Sie dieses TextContext
-Objekt zur Wiederverwendung speichern, führt dies in den meisten Fällen zu Problemen.
Behandeln von Verstößen
Speichern Sie die [AssemblyInitialize]
-Parameter [ClassInitialize]
oder TestContext
nicht.
Wann sollten Warnungen unterdrückt werden?
Sie können Warnungen von dieser Regel unterdrücken, wenn Sie sich sicher sind, dass das Verhalten Ihren Erwartungen entspricht.
Unterdrücken einer Warnung
Um nur eine einzelne Verletzung zu unterdrücken, fügen Sie der Quelldatei Präprozessoranweisungen hinzu, um die Regel zu deaktivieren und dann wieder zu aktivieren.
#pragma warning disable MSTEST0024
// The code that's violating the rule is on this line.
#pragma warning restore MSTEST0024
Um die Regel für eine Datei, einen Ordner oder ein Projekt zu deaktivieren, legen Sie den Schweregrad in der Konfigurationsdatei auf none
fest.
[*.{cs,vb}]
dotnet_diagnostic.MSTEST0024.severity = none
Weitere Informationen finden Sie unter Vorgehensweise: Unterdrücken von Codeanalyse-Warnungen.