Microsoft.VisualStudio.DiagnosticsHub.VSTestPerformanceCollector
18.6.37125.3
Prefix Reserved
dotnet add package Microsoft.VisualStudio.DiagnosticsHub.VSTestPerformanceCollector --version 18.6.37125.3
NuGet\Install-Package Microsoft.VisualStudio.DiagnosticsHub.VSTestPerformanceCollector -Version 18.6.37125.3
This command is intended to be used within the Package Manager Console in Visual Studio, as it uses the NuGet module's version of Install-Package.
<PackageReference Include="Microsoft.VisualStudio.DiagnosticsHub.VSTestPerformanceCollector" Version="18.6.37125.3"> <PrivateAssets>all</PrivateAssets> <IncludeAssets>runtime; build; native; contentfiles; analyzers</IncludeAssets> </PackageReference>
For projects that support PackageReference, copy this XML node into the project file to reference the package.
<PackageVersion Include="Microsoft.VisualStudio.DiagnosticsHub.VSTestPerformanceCollector" Version="18.6.37125.3" />
<PackageReference Include="Microsoft.VisualStudio.DiagnosticsHub.VSTestPerformanceCollector"> <PrivateAssets>all</PrivateAssets> <IncludeAssets>runtime; build; native; contentfiles; analyzers</IncludeAssets> </PackageReference>
For projects that support Central Package Management (CPM), copy this XML node into the solution Directory.Packages.props file to version the package.
paket add Microsoft.VisualStudio.DiagnosticsHub.VSTestPerformanceCollector --version 18.6.37125.3
The NuGet Team does not provide support for this client. Please contact its maintainers for support.
#r "nuget: Microsoft.VisualStudio.DiagnosticsHub.VSTestPerformanceCollector, 18.6.37125.3"
#r directive can be used in F# Interactive and Polyglot Notebooks. Copy this into the interactive tool or source code of the script to reference the package.
#:package Microsoft.VisualStudio.DiagnosticsHub.VSTestPerformanceCollector@18.6.37125.3
#:package directive can be used in C# file-based apps starting in .NET 10 preview 4. Copy this into a .cs file before any lines of code to reference the package.
#addin nuget:?package=Microsoft.VisualStudio.DiagnosticsHub.VSTestPerformanceCollector&version=18.6.37125.3
#tool nuget:?package=Microsoft.VisualStudio.DiagnosticsHub.VSTestPerformanceCollector&version=18.6.37125.3
The NuGet Team does not provide support for this client. Please contact its maintainers for support.
Microsoft.VisualStudio.DiagnosticsHub.VSTestPerformanceCollector
VSTest DataCollectors for performance profiling during test runs, producing .diagsession files that can be analyzed in Visual Studio's Performance Profiler.
Available Collectors
- CpuUsageCollector - CPU profiling to identify performance bottlenecks
Requirements
- Visual Studio 2022 (17.11 or later) or Visual Studio Remote Tools must be installed
- Windows x64
Installation
dotnet add package Microsoft.VisualStudio.DiagnosticsHub.VSTestPerformanceCollector
Usage
Option 1: Via .runsettings File (Recommended)
Create a .runsettings file with the following configuration:
<?xml version="1.0" encoding="utf-8"?>
<RunSettings>
<DataCollectionRunSettings>
<DataCollectors>
<DataCollector friendlyName="CpuUsageCollector"
uri="datacollector://Microsoft/CpuUsageCollector/1.0"
enabled="True">
<Configuration>
<AttachToTestResults>true</AttachToTestResults>
</Configuration>
</DataCollector>
</DataCollectors>
</DataCollectionRunSettings>
</RunSettings>
Then run your tests:
dotnet test --settings my.runsettings
Option 2: Via CLI Argument
dotnet test --collect:"CpuUsageCollector"
Note: This uses default configuration. Custom settings require a .runsettings file.
Configuration Options
| Option | Type | Default | Description |
|---|---|---|---|
OutputPath |
string | TestResults folder | Directory for .diagsession output |
AttachToTestResults |
bool | true | Attach diagsession to test results |
Analyzing Results
The .diagsession files produced by the collector can be opened with Visual Studio.
CI Pipeline Integration
Azure DevOps
- task: VSTest@2
inputs:
testSelector: 'testAssemblies'
testAssemblyVer2: '**/*Tests.dll'
runSettingsFile: 'test.runsettings'
displayName: 'Run Tests with Performance Profiling'
- task: PublishPipelineArtifact@1
inputs:
targetPath: '$(Agent.TempDirectory)/TestResults'
artifact: 'PerformanceProfilingResults'
displayName: 'Publish Diagsession Files'
condition: always()
GitHub Actions
- name: Run Tests with Performance Profiling
run: dotnet test --settings test.runsettings --logger trx --results-directory TestResults
- name: Upload Performance Profiling Results
uses: actions/upload-artifact@v4
with:
name: performance-profiling-results
path: TestResults/**/*.diagsession
if: always()
License
See LICENSE.md in the package for license terms.
| Product | Versions Compatible and additional computed target framework versions. |
|---|---|
| .NET | net5.0 was computed. net5.0-windows was computed. net6.0 was computed. net6.0-android was computed. net6.0-ios was computed. net6.0-maccatalyst was computed. net6.0-macos was computed. net6.0-tvos was computed. net6.0-windows was computed. net7.0 was computed. net7.0-android was computed. net7.0-ios was computed. net7.0-maccatalyst was computed. net7.0-macos was computed. net7.0-tvos was computed. net7.0-windows was computed. net8.0 was computed. net8.0-android was computed. net8.0-browser was computed. net8.0-ios was computed. net8.0-maccatalyst was computed. net8.0-macos was computed. net8.0-tvos was computed. net8.0-windows was computed. net9.0 was computed. net9.0-android was computed. net9.0-browser was computed. net9.0-ios was computed. net9.0-maccatalyst was computed. net9.0-macos was computed. net9.0-tvos was computed. net9.0-windows was computed. net10.0 was computed. net10.0-android was computed. net10.0-browser was computed. net10.0-ios was computed. net10.0-maccatalyst was computed. net10.0-macos was computed. net10.0-tvos was computed. net10.0-windows was computed. |
| .NET Core | netcoreapp2.0 was computed. netcoreapp2.1 was computed. netcoreapp2.2 was computed. netcoreapp3.0 was computed. netcoreapp3.1 was computed. |
| .NET Standard | netstandard2.0 is compatible. netstandard2.1 was computed. |
| .NET Framework | net461 was computed. net462 was computed. net463 was computed. net47 was computed. net471 was computed. net472 was computed. net48 was computed. net481 was computed. |
| MonoAndroid | monoandroid was computed. |
| MonoMac | monomac was computed. |
| MonoTouch | monotouch was computed. |
| Tizen | tizen40 was computed. tizen60 was computed. |
| Xamarin.iOS | xamarinios was computed. |
| Xamarin.Mac | xamarinmac was computed. |
| Xamarin.TVOS | xamarintvos was computed. |
| Xamarin.WatchOS | xamarinwatchos was computed. |
Compatible target framework(s)
Included target framework(s) (in package)
Learn more about Target Frameworks and .NET Standard.
-
.NETStandard 2.0
- Newtonsoft.Json (>= 13.0.1)
NuGet packages
This package is not used by any NuGet packages.
GitHub repositories
This package is not used by any popular GitHub repositories.
| Version | Downloads | Last Updated |
|---|---|---|
| 18.6.37125.3 | 31 | 3/26/2026 |