A modern, high-performance test framework for .NET 10+ with zero-reflection execution and xUnit-style assertions.
- Zero-reflection execution - Source generators produce delegate-based test registry
- Familiar assertions -
Assert.Equal,Assert.True,Assert.Throws, etc. - Multi-scope lifecycle -
[Before]/[After]at Test, Class, Assembly, or Session level - Fine-grained parallelism -
[ParallelLimit(N)],[NotInParallel] - Parameterized tests -
[Arguments]and[TestData]attributes - Category/Tag filtering -
[Category],[Tag]with CLI and environment variable support - Test dependencies -
[DependsOn]for ordered execution - VSTest integration - Works with Visual Studio Test Explorer and
dotnet test - Native AOT compatible
dotnet add package NextUnit<Project Sdk="Microsoft.NET.Sdk">
<PropertyGroup>
<TargetFramework>net10.0</TargetFramework>
</PropertyGroup>
<ItemGroup>
<PackageReference Include="NextUnit" Version="1.6.6" />
</ItemGroup>
</Project>using NextUnit;
public class CalculatorTests
{
[Test]
public void Add_ReturnsSum()
{
Assert.Equal(4, 2 + 2);
}
[Test]
public void Divide_ThrowsOnZero()
{
Assert.Throws<DivideByZeroException>(() => { var x = 1 / 0; });
}
[Test]
[Arguments(2, 3, 5)]
[Arguments(-1, 1, 0)]
public void Add_Parameterized(int a, int b, int expected)
{
Assert.Equal(expected, a + b);
}
}dotnet test # Run all tests
dotnet test --filter "FullyQualifiedName~Calc" # Filter by name| Category | Methods |
|---|---|
| Basic | Equal, NotEqual, True, False, Null, NotNull |
| Collections | Contains, DoesNotContain, Empty, NotEmpty, Single, All |
| Strings | StartsWith, EndsWith, Contains |
| Numeric | InRange, NotInRange, Equal(expected, actual, precision) |
| Exceptions | Throws<T>, ThrowsAsync<T> |
| Advanced | Equivalent, Subset, Disjoint |
public class DatabaseTests
{
[Before(LifecycleScope.Test)] // Before each test
public void Setup() { }
[After(LifecycleScope.Test)] // After each test
public void Cleanup() { }
[Before(LifecycleScope.Class)] // Once before all tests in class
public void ClassSetup() { }
[Test]
public void MyTest() { }
}Scopes: Test, Class, Assembly, Session
[NotInParallel] // Run tests serially
public class SlowTests { }
[ParallelLimit(2)] // Max 2 concurrent tests
public class ModerateTests { }[Category("Integration")]
[Tag("Slow")]
public class MyTests { }# Environment variables
NEXTUNIT_INCLUDE_CATEGORIES=Integration dotnet test
NEXTUNIT_EXCLUDE_TAGS=Slow dotnet test| Metric | Result |
|---|---|
| Discovery (1,000 tests) | ~2ms |
| Per-test overhead | ~0.7ms |
| Throughput | 1,852 tests/sec |
See benchmark results for comparison with xUnit, NUnit, and MSTest.
- Getting Started
- Migration from xUnit
- Best Practices
- Performance Analysis
- CI/CD Integration
- Changelog
- Class Library Testing - Business logic testing patterns
- Console App Testing - CLI argument parsing, file processing
- Framework Tests - All NextUnit features demonstrated
- Open an issue to discuss your idea
- Fork and create a feature branch
- Write tests for your changes
- Submit a PR
Note: English-only for code, comments, and documentation.
dotnet build --configuration Release
dotnet test samples/NextUnit.SampleTests/NextUnit.SampleTests.csprojInspired by TUnit (architecture), xUnit (assertions), and NUnit/MSTest.