csharp-xunit
Scannednpx machina-cli add skill github/awesome-copilot/csharp-xunit --openclawFiles (1)
SKILL.md
2.6 KB
XUnit Best Practices
Your goal is to help me write effective unit tests with XUnit, covering both standard and data-driven testing approaches.
Project Setup
- Use a separate test project with naming convention
[ProjectName].Tests - Reference Microsoft.NET.Test.Sdk, xunit, and xunit.runner.visualstudio packages
- Create test classes that match the classes being tested (e.g.,
CalculatorTestsforCalculator) - Use .NET SDK test commands:
dotnet testfor running tests
Test Structure
- No test class attributes required (unlike MSTest/NUnit)
- Use fact-based tests with
[Fact]attribute for simple tests - Follow the Arrange-Act-Assert (AAA) pattern
- Name tests using the pattern
MethodName_Scenario_ExpectedBehavior - Use constructor for setup and
IDisposable.Dispose()for teardown - Use
IClassFixture<T>for shared context between tests in a class - Use
ICollectionFixture<T>for shared context between multiple test classes
Standard Tests
- Keep tests focused on a single behavior
- Avoid testing multiple behaviors in one test method
- Use clear assertions that express intent
- Include only the assertions needed to verify the test case
- Make tests independent and idempotent (can run in any order)
- Avoid test interdependencies
Data-Driven Tests
- Use
[Theory]combined with data source attributes - Use
[InlineData]for inline test data - Use
[MemberData]for method-based test data - Use
[ClassData]for class-based test data - Create custom data attributes by implementing
DataAttribute - Use meaningful parameter names in data-driven tests
Assertions
- Use
Assert.Equalfor value equality - Use
Assert.Samefor reference equality - Use
Assert.True/Assert.Falsefor boolean conditions - Use
Assert.Contains/Assert.DoesNotContainfor collections - Use
Assert.Matches/Assert.DoesNotMatchfor regex pattern matching - Use
Assert.Throws<T>orawait Assert.ThrowsAsync<T>to test exceptions - Use fluent assertions library for more readable assertions
Mocking and Isolation
- Consider using Moq or NSubstitute alongside XUnit
- Mock dependencies to isolate units under test
- Use interfaces to facilitate mocking
- Consider using a DI container for complex test setups
Test Organization
- Group tests by feature or component
- Use
[Trait("Category", "CategoryName")]for categorization - Use collection fixtures to group tests with shared dependencies
- Consider output helpers (
ITestOutputHelper) for test diagnostics - Skip tests conditionally with
Skip = "reason"in fact/theory attributes
Source
git clone https://github.com/github/awesome-copilot/blob/main/plugins/csharp-dotnet-development/skills/csharp-xunit/SKILL.mdView on GitHub Overview
This skill captures practical XUnit testing patterns for .NET projects, including standard and data-driven tests. It guides project setup, test structure, assertions, mocking, and organization to help you write reliable and maintainable unit tests.
How This Skill Works
XUnit tests use [Fact] for single-case tests and [Theory] for data-driven scenarios. Tests should follow AAA (Arrange, Act, Assert) and be organized by feature, using constructors or fixtures for setup and shared context. The guidance also covers mock isolation and clear, descriptive test naming.
When to Use It
- Starting a new .NET project and adding a dedicated test project named [ProjectName].Tests
- Writing simple unit tests that verify a single behavior using [Fact]
- Implementing data-driven tests with [Theory] and data sources like [InlineData], [MemberData], or [ClassData]
- Isolating units under test with mocks (Moq/NSubstitute) and dependency injection
- Organizing tests by feature and using fixtures for shared context
Quick Start
- Step 1: Create a test project named [ProjectName].Tests and add Microsoft.NET.Test.Sdk, xunit, and xunit.runner.visualstudio
- Step 2: Write a [Fact]-based test using AAA and a descriptive name like MethodName_Scenario_ExpectedBehavior
- Step 3: Run dotnet test; convert to data-driven tests with [Theory] and data sources like InlineData, MemberData, or ClassData
Best Practices
- Keep tests focused on a single behavior and clear assertions
- Name tests as MethodName_Scenario_ExpectedBehavior and follow AAA
- Use constructor for setup and IDisposable for teardown; apply IClassFixture or ICollectionFixture for shared context
- Prefer [Theory] with data sources over writing multiple similar [Fact] tests
- Group tests by feature, enable test categorization, and document failures with meaningful Skip or Traits
Example Use Cases
- CalculatorTests.Add_SimpleValue_ReturnsSum
- ShoppingCart_Total_WithInlineData_DiscountsApplied
- UserRepository_GetUser_ById_ReturnsUser_MockDependencies
- Calculator_Divide_ByZero_ThrowsException
- DiscountService_Apply_WithMemberData_ReturnsExpectedTotal
Frequently Asked Questions
Add this skill to your agents