Dela via


MSTest-kodanalys

MSTest-analysregler ("MSTESTxxxx") kontrollerar din C#- eller Visual Basic-kod för säkerhet, prestanda, design och andra problem.

Dricks

Om du använder Visual Studio har många analysregler associerade kodkorrigeringar som du kan använda för att åtgärda problemet. Kodkorrigeringar visas i menyn med glödlampans ikon.

Reglerna är ordnade i kategorier som prestandaanvändning...

Från och med MSTest.TestFramework 3.7 är NUGet-paketet MSTest.Analyzeers ett beroende av ramverket. För tidigare versioner måste du använda MSTest metapaket eller lägga till en paketreferens för MSTest.Analyzers explicit.

MSTestAnalysisMode (på engelska)

Från och med MSTest 3.8 är en MSBuild-egenskap med namnet MSTestAnalysisMode tillgänglig för att avgöra vilka analysverktyg som är aktiverade med vilken allvarlighetsgrad.

Dricks

Om du vill se vilka regler som är aktiverade med vilken allvarlighetsgrad för varje läge kan du navigera till paketet med den aktuella versionen i NuGet-cachen, leta upp katalogen globalconfigs och öppna den .globalconfig fil som motsvarar analysläget. Mer information om hur du hittar NuGet-cachekatalogen finns i Hantera globala paket, cacheminnen och temporära mappar. Leta rätt på mstest.analyzers-katalogen i den aktuella katalogen, sedan versionen (3.8 och senare), och därefter globalconfigs. Du kan också ladda ned NuGet-paketet för den aktuella versionen från nuget.org och visa det i NuGet Package Explorer (Windows-app) eller visa det direkt i webbappsversionen av NuGet Package Explorer.

Tillgängliga värden för den här egenskapen:

None

Det här värdet ställer in alla analysverktyg på none allvarlighetsgrad och inaktiverar alla. Du kan sedan aktivera enskilda analysverktyg med hjälp av .editorconfig eller .globalconfig filer.

Default

Den här inställningen följer det dokumenterade standardbeteendet för varje regel.

  • Regler som är aktiverade som standard använder sin standard allvarlighetsgrad.
  • Regler som är inaktiverade som standard använder none allvarlighetsgrad.

Anmärkning

Regler som är aktiverade som standard som varningar är överträdelser som förväntas orsaka problem vid körning.

Det här är det läge som de flesta utvecklare förväntas använda. Regler som är aktiverade som standard med allvarlighetsgraden Info (suggestion) eskaleras till varningar. Följande regler eskaleras till fel i både Recommended-lägena och All-lägena.

All

Det här läget är mer aggressivt än Recommended. Alla regler är aktiverade som varningar. Dessutom eskaleras följande regler till fel:

Regler efter kategori

Analysreglerna är indelat i följande kategorier:

Designregler

Designregler hjälper dig att skapa och underhålla testsviter som följer rätt design och god praxis.

Prestandaregler

Prestandaregler stöder testning med höga prestanda.

Regler för undertryckning

Undertryckningsregler stödjer undertryckande av diagnostik från andra regler.

Användningsregler

Användningsregler stöder korrekt användning av MSTest.

Regler efter begrepp

Hitta regler ordnade efter vanliga testscenarier och begrepp:

Testa struktur och attribut

Regler som hjälper dig att se till att dina testklasser och metoder är korrekt strukturerade och dekorerade:

  • MSTEST0002 – Testklassen ska vara giltig
  • MSTEST0003 – Testmetoden ska vara giltig
  • MSTEST0004 – Offentliga typer ska vara testklasser
  • MSTEST0007 – Använd attributet på testmetoden
  • MSTEST0016 – Testklassen ska ha testmetod
  • MSTEST0029 – Offentlig metod ska vara testmetod
  • MSTEST0030 – Typ som innehåller testmetoden ska vara en testklass
  • MSTEST0036 – Använd inte skuggning
  • MSTEST0041 – Använda villkorsbaserade attribut med testklass
  • MSTEST0044 – Föredrar TestMethod framför DataTestMethod
  • MSTEST0056 – TestMethodAttribute bör ange DisplayName korrekt
  • MSTEST0057 – TestMethodAttribute bör sprida källinformation
  • MSTEST0060 – Duplicerad TestMethodAttribute
  • MSTEST0063 – Testklassen ska ha en giltig konstruktor

Relaterad dokumentation: Skriva tester med MSTest

Async/await-mönster

Regler för att skriva asynkron testkod korrekt:

  • MSTEST0013 – AssemblyCleanup ska vara giltigt (inkluderar asynkrona regler)
  • MSTEST0027 – Utelämna asynkront suffix för testmetoder
  • MSTEST0028 – Utelämna asynkront suffix för testfixturmetoder
  • MSTEST0039 – Använd nyare Assert.Throws-metoder (asynkrona varianter)
  • MSTEST0040 – Undvik att använda asserts i asynkron void-kontekst
  • MSTEST0045 – Använd kooperativ annullering för timeout
  • MSTEST0049 – Flow TestContext CancellationToken
  • MSTEST0054 – Använd egenskapen CancellationToken

Relaterad dokumentation: TestContext

Datadriven testning

Regler för att arbeta med datadrivna testscenarier:

Relaterad dokumentation: Datadriven testning

Livscykel och initiering

Regler för testinitiering, rensning och livscykelhantering:

  • MSTEST0008 – TestInitialize ska vara giltigt
  • MSTEST0009 – TestCleanup ska vara giltigt
  • MSTEST0010 – ClassInitialize ska vara giltigt
  • MSTEST0011 – ClassCleanup ska vara giltigt
  • MSTEST0012 – AssemblyInitialize ska vara giltigt
  • MSTEST0013 – AssemblyCleanup ska vara giltigt
  • MSTEST0019 – Föredrar TestInitialisera framför konstruktorer
  • MSTEST0020 – Föredrar konstruktorer framför TestInitialize
  • MSTEST0021 – Föredra Dispose framför TestCleanup
  • MSTEST0022 – Föredra TestCleanup framför Dispose
  • MSTEST0034 – Använd ClassCleanupBehavior.EndOfClass
  • MSTEST0050 – Den globala testfixturen ska vara giltig

Relaterad dokumentation: Livscykel

Assertions

Regler för att använda kontrollmetoder korrekt och effektivt:

  • MSTEST0006 – Undvik attributet ExpectedException
  • MSTEST0014 – DataRow ska vara giltigt
  • MSTEST0017 – Påståendeargument bör skickas i rätt ordning
  • MSTEST0023 – Negera inte booleskt påstående
  • MSTEST0025 – Föredrar Assert.Fail framför villkor som alltid är falska
  • MSTEST0026 – Asserts args bör undvika villkorlig åtkomst
  • MSTEST0032 – Granska villkor för always-true-kontroll
  • MSTEST0037 – Använd rätt assertmetoder
  • MSTEST0038 – Undvik Assert.AreSame med värdetyper
  • MSTEST0039 – Använd nyare Assert.Throws-metoder
  • MSTEST0046 – Använd Assert i stället för StringAssert
  • MSTEST0051 – Assert.Throws ska innehålla en enda instruktion
  • MSTEST0053 – Undvik parametrar för Assert-format
  • MSTEST0058 – Undvik kontroller i fångstblock

Relaterad dokumentation: Intyg

TestContext

Regler för korrekt användning av TestContext-objektet:

  • MSTEST0005 – TestContext ska vara giltigt
  • MSTEST0024 – Lagra inte statisk TestContext
  • MSTEST0033 – Ignorera icke-nullbar referens som inte initierats varning
  • MSTEST0048 – TestContext-egenskapsanvändning
  • MSTEST0049 – Flow TestContext CancellationToken
  • MSTEST0054 – Använd egenskapen CancellationToken

Relaterad dokumentation: TestContext

Testkonfiguration

Regler för att konfigurera testkörning, parallellisering och andra testinställningar:

  • MSTEST0001 – Använd attributet Parallelize
  • MSTEST0015 – Testmetoden bör inte ignoreras
  • MSTEST0031 – Använd inte System.ComponentModel.DescriptionAttribute
  • MSTEST0035 – Använda DeploymentItem med testmetod eller testklass
  • MSTEST0043 – Använd återförsöksattribut på testmetoden
  • MSTEST0045 – Använd kooperativ annullering för timeout
  • MSTEST0055 – Ignorera inte strängmetodens returvärde
  • MSTEST0059 – Använd attributet Parallelize korrekt
  • MSTEST0061 – Använd OSCondition-attribut i stället för körningskontroll

Relaterad dokumentation: Konfigurera MSTest, Köra tester

Alla regler (snabböversikt)

Regel-ID Kategori Titel Standard allvarlighetsgrad
MSTEST0001 Performance Använda attributet Parallelize Info
MSTEST0002 Usage Testklassen måste vara giltig Varning
MSTEST0003 Usage Testmetoden ska vara giltig Varning → Fel*
MSTEST0004 Design Offentliga typer bör betraktas som testklasser. Info
MSTEST0005 Usage TestContext ska vara giltigt Varning
MSTEST0006 Design Undvik attributet ExpectedException Info
MSTEST0007 Usage Använd attribut på testmetoden Varning
MSTEST0008 Usage TestInitialize ska vara giltigt Varning
MSTEST0009 Usage TestCleanup ska vara giltig Varning
MSTEST0010 Usage ClassInitialize ska vara giltigt Varning
MSTEST0011 Usage ClassCleanup ska vara giltigt Varning
MSTEST0012 Usage AssemblyInitialize ska vara giltigt Varning
MSTEST0013 Usage AssemblyCleanup ska vara giltigt Varning
MSTEST0014 Usage DataRow ska vara giltig Varning
MSTEST0015 Design Testmetoden bör inte ignoreras Ingen (valfritt)
MSTEST0016 Design Testklassen ska ha en testmetod Info
MSTEST0017 Usage Kontroll args bör skickas i rätt ordning Info
MSTEST0018 Usage DynamicData ska vara giltigt Varning
MSTEST0019 Design Föredrar TestInitialize framför konstruktorer Ingen (valfritt)
MSTEST0020 Design Föredrar konstruktorer framför TestInitialize Ingen (valfritt)
MSTEST0021 Design Föredrar att göra sig av med TestCleanup Ingen (valfritt)
MSTEST0022 Design Föredra TestCleanup framför Dispose Ingen (valfritt)
MSTEST0023 Usage Förneka inte boolesk försäkran Info
MSTEST0024 Usage Lagra inte statisk TestContext Varning
MSTEST0025 Design Föredrar Assert.Fail framför villkor som alltid är falska Info
MSTEST0026 Usage Påståenden Args bör undvika villkorlig åtkomst Info
MSTEST0027 Suppression Ignorera asynkront suffix för testmetoder N/A
MSTEST0028 Suppression Utelämna asynkront suffix för testfixturmetoder N/A
MSTEST0029 Design Offentlig metod ska vara testmetod Info
MSTEST0030 Usage Typ som innehåller testmetoden ska vara en testklass Varning
MSTEST0031 Usage Använd inte System.ComponentModel.DescriptionAttribute Info
MSTEST0032 Usage Granska villkor för always-true-kontroll Info
MSTEST0033 Suppression Ignorera icke-nullbar referens som inte initierats N/A
MSTEST0034 Usage Använd ClassCleanupBehavior.EndOfClass Info
MSTEST0035 Usage Använda DeploymentItem med testmetoden eller testklassen Info
MSTEST0036 Design Använd inte skuggning Varning
MSTEST0037 Usage Använd rätt assert-metoder Info
MSTEST0038 Usage Undvik Assert.AreSame med värdetyper Info
MSTEST0039 Usage Använd nyare Assert.Throws-metoder Info
MSTEST0040 Usage Undvik att använda asserts i asynkron void-context Varning
MSTEST0041 Usage Använda villkorsbaserade attribut med testklass Varning
MSTEST0042 Usage Duplicera DataRow Varning
MSTEST0043 Usage Använda återförsöksattribut för testmetoden Varning → Fel*
MSTEST0044 Design Föredrar TestMethod framför DataTestMethod Info
MSTEST0045 Design Använd kooperativ annullering för timeout Info
MSTEST0046 Usage Använd Assert i stället för StringAssert Info
MSTEST0048 Usage TestContext-egenskapsanvändning Varning
MSTEST0049 Usage Flow-TestContext-CancellationToken Info
MSTEST0050 Usage Den globala testmiljön ska vara giltig Varning
MSTEST0051 Usage Assert.Throws ska innehålla en enda instruktion Info
MSTEST0052 Usage Undvik uttrycklig DynamicDataSourceType Info
MSTEST0053 Usage Undvik parametrar för Assert-format Info
MSTEST0054 Usage Använda egenskapen CancellationToken Info
MSTEST0055 Usage Ignorera inte strängmetodens returvärde Varning
MSTEST0056 Usage TestMethodAttribute ska korrekt sätta DisplayName Info
MSTEST0057 Usage TestMethodAttribute bör sprida källinformation Varning
MSTEST0058 Usage Undvik assertioner i fångstblock Info
MSTEST0059 Usage Använd attributet Parallelize korrekt Varning
MSTEST0060 Usage Duplicera TestMethodAttribute Varning
MSTEST0061 Usage Använd OSCondition-attributet istället för runtime-kontroll Info
MSTEST0062 Usage Undvik testmetodparametrar för out/ref Varning
MSTEST0063 Usage Testklassen ska ha en giltig konstruktor Varning

* Eskalerade till Fel i Recommended och All lägen.

MSTESTEXP

Flera API:er för MSTest är dekorerade med ExperimentalAttribute. Det här attributet anger att API:et är experimentellt och kan tas bort eller ändras i framtida versioner av MSTest. Attributet används för att identifiera API:er som ännu inte är stabila och kanske inte är lämpliga för produktionsanvändning.

MSTESTEXP-diagnostikvarningen meddelar dig om användningen av en experimentell API i koden. Om du vill förhindra den här diagnostiken med SuppressMessageAttributelägger du till följande kod i projektet:

using System.Diagnostics.CodeAnalysis;

[assembly: SuppressMessage("MSTESTEXP", "Justification")]

Du kan också ignorera den här diagnostiken med förprocessordirektivet genom att lägga till följande kod i projektet:

#pragma warning disable MSTESTEXP
        // API that is causing the warning.
#pragma warning restore MSTESTEXP