Dotnet-skills dotnet-mstest
Write, run, or repair .NET tests that use MSTest. Use when a repo uses `MSTest.Sdk`, `MSTest`, `[TestClass]`, `[TestMethod]`, `DataRow`, or Microsoft.Testing.Platform-based MSTest execution.
install
source · Clone the upstream repo
git clone https://github.com/managedcode/dotnet-skills
Claude Code · Install into ~/.claude/skills/
T=$(mktemp -d) && git clone --depth=1 https://github.com/managedcode/dotnet-skills "$T" && mkdir -p ~/.claude/skills && cp -r "$T/catalog/Testing/MSTest/skills/dotnet-mstest" ~/.claude/skills/managedcode-dotnet-skills-dotnet-mstest && rm -rf "$T"
manifest:
catalog/Testing/MSTest/skills/dotnet-mstest/SKILL.mdsource content
MSTest
Trigger On
- the repo uses MSTest
- you need to add, run, debug, or repair MSTest tests
- the repo is moving between VSTest and Microsoft.Testing.Platform
Value
- produce a concrete project delta: code, docs, config, tests, CI, or review artifact
- reduce ambiguity through explicit planning, verification, and final validation skills
- leave reusable project context so future tasks are faster and safer
Do Not Use For
- xUnit projects
- TUnit projects
- generic test strategy with no MSTest-specific mechanics
Inputs
- the nearest
AGENTS.md - the test project file and package references
- the active MSTest runner model
Quick Start
- Read the nearest
and confirm scope and constraints.AGENTS.md - Run this skill's
through theWorkflow
until outcomes are acceptable.Ralph Loop - Return the
with concrete artifacts and verification evidence.Required Result Format
Workflow
- Detect the MSTest project style first:
project SDKMSTest.Sdk
meta-packageMSTest- legacy package set with explicit
Microsoft.NET.Test.Sdk
- Read the repo's real
command fromtest
. If the repo has no explicit command yet, start withAGENTS.md
.dotnet test PROJECT_OR_SOLUTION - Keep the runner model consistent:
defaults to the MSTest runner on Microsoft.Testing.PlatformMSTest.Sdk- VSTest is opt-in with
or legacy package choicesUseVSTest=true - do not pass VSTest-only switches or assume legacy
behavior on Microsoft.Testing.Platform jobs.runsettings
- Prefer
or[DataRow]
for stable data-driven coverage. Keep test lifecycle hooks minimal and deterministic.DynamicData - Keep MSTest analyzers enabled and fix findings instead of muting them casually.
- Align coverage/reporting packages with the active runner.
Bootstrap When Missing
If MSTest is requested but not configured:
- Detect current framework first:
rg -n "MSTest\\.Sdk|PackageReference Include=\"MSTest\"|xunit|TUnit|UseVSTest|TestingPlatformDotnetTestSupport" -g '*.csproj' .
- If the repo currently uses
orxUnit
, do not auto-migrate. ReturnTUnit
unless migration is explicitly requested.status: not_applicable - For explicit MSTest adoption, add package(s) to target test project:
dotnet add TEST_PROJECT.csproj package MSTest
- Document runner model (
default MTP vsMSTest.Sdk
) inUseVSTest
.AGENTS.md - Run
and returndotnet test TEST_PROJECT.csproj
orstatus: configured
.status: improved
Deliver
- MSTest tests that match the repo's runner model
- commands that work in local and CI runs
- explicit guidance for VSTest versus Microsoft.Testing.Platform usage
Validate
- the runner model is documented and consistent
- test commands match that runner
- data-driven tests stay deterministic
- analyzer, coverage, and reporting packages align with the chosen runner
Ralph Loop
Use the Ralph Loop for every task, including docs, architecture, testing, and tooling work.
- Plan first (mandatory):
- analyze current state
- define target outcome, constraints, and risks
- write a detailed execution plan
- list final validation skills to run at the end, with order and reason
- Execute one planned step and produce a concrete delta.
- Review the result and capture findings with actionable next fixes.
- Apply fixes in small batches and rerun the relevant checks or review steps.
- Update the plan after each iteration.
- Repeat until outcomes are acceptable or only explicit exceptions remain.
- If a dependency is missing, bootstrap it or return
with explicit reason and fallback path.status: not_applicable
Required Result Format
:status
|complete
|clean
|improved
|configured
|not_applicableblocked
: concise plan and current iteration stepplan
: concrete changes madeactions_taken
: final skills run, or skipped with reasonsvalidation_skills
: commands, checks, or review evidence summaryverification
: top unresolved items orremainingnone
For setup-only requests with no execution, return
status: configured and exact next commands.
Load References
references/mstest.mdreferences/patterns.mdreferences/anti-patterns.md
Example Requests
- "Fix our MSTest runner setup."
- "Add an MSTest regression test."
- "Move this MSTest project to Microsoft.Testing.Platform safely."