Dela via


Utvidgningar för kodtäckning

I den här artikeln listas och förklaras alla Microsoft Testing Platform-tillägg som är relaterade till kapaciteten för kodtäckning.

Du kan använda funktionen för kodtäckning för att avgöra vilken andel av projektets kod som testas av kodade tester, till exempel enhetstester. För att effektivt försvara dig mot buggar bör dina tester omfatta eller täcka en stor del av din kod.

Microsofts kodtäckning

Microsoft Code Coverage-analys är möjlig för både hanterad (CLR) och ohanterad (intern) kod. Både statisk och dynamisk instrumentering stöds. Det här tillägget levereras som en del av Microsoft.Testing.Extensions.CodeCoverage NuGet-paketet.

Not

Ohanterad (intern) kodtäckning är inaktiverad i tillägget som standard. Använd flaggor EnableStaticNativeInstrumentation och EnableDynamicNativeInstrumentation för att aktivera den om det behövs. Mer information om ohanterad kodtäckning finns i Statisk och dynamisk intern instrumentation.

Viktig

Paketet levereras med Microsoft .NET-biblioteket under en licensmodell med stängd källkod som är gratis att använda.

Mer information om Microsofts kodtäckning finns på sidan GitHub.

Microsoft Code Coverage innehåller följande alternativ:

Alternativ Beskrivning
--coverage Samla in kodtäckningen med hjälp av verktyget dotnet-coverage.
--coverage-output Namnet eller sökvägen till den skapade täckningsfilen. Som standard är filen TestResults/<guid>.coverage.
--coverage-output-format Utdatafilformat. Värden som stöds är: coverage, xmloch cobertura. Standardvärdet är coverage.
--coverage-settings XML-kodtäckningsinställningar.

Mer information om tillgängliga alternativ finns i inställningar och exempel.

Överkast

Viktig

NuGet-paketet coverlet.collector är särskilt utformat för VSTest och kan inte användas med Microsoft.Testing.Platform.

Det finns för närvarande inget Coverlet-tillägg, men du kan använda det globala verktyget Coverlet .NET.

Förutsatt att du redan har installerat det globala Coverlet-verktyget kan du nu köra:

coverlet .\bin\Debug\net8.0\TestProject2.dll --target "dotnet" --targetargs "test .\bin\Debug\net8.0\TestProject2.dll --no-build"