TUnit 1.18.0
Prefix Reserveddotnet add package TUnit --version 1.18.0
NuGet\Install-Package TUnit -Version 1.18.0
<PackageReference Include="TUnit" Version="1.18.0" />
<PackageVersion Include="TUnit" Version="1.18.0" />
<PackageReference Include="TUnit" />
paket add TUnit --version 1.18.0
#r "nuget: TUnit, 1.18.0"
#:package TUnit@1.18.0
#addin nuget:?package=TUnit&version=1.18.0
#tool nuget:?package=TUnit&version=1.18.0
TUnit
A modern .NET testing framework. Tests are source-generated at compile time, run in parallel by default, and support Native AOT — all built on Microsoft.Testing.Platform.
<div align="center">
</div>
Features
- Compile-time test discovery — tests are generated at build time rather than discovered via reflection at runtime, which means faster startup and better IDE integration
- Parallel by default — tests run concurrently; use
[DependsOn]to express ordering and[ParallelLimiter]to cap concurrency - Data-driven testing —
[Arguments],[Matrix],[ClassData], and customDataSourceGenerator<T>sources - Async assertions with detailed failure messages
- Built-in Roslyn analyzers — catch mistakes at compile time, such as missing
async, incorrect method signatures, and invalid attribute combinations - Extensible — write your own skip conditions, retry logic, and attributes
- Native AOT & trimming support
- Lifecycle hooks —
[Before]/[After]at method, class, assembly, or test session scope
Getting Started
Using the Project Template (Recommended)
dotnet new install TUnit.Templates
dotnet new TUnit -n "MyTestProject"
cd MyTestProject
dotnet run
Manual Installation
dotnet add package TUnit
Getting Started Guide · Migration Guides
Examples
Basic test with assertions
[Test]
public async Task Parsing_A_Valid_Date_Succeeds()
{
var date = DateTime.Parse("2025-01-01");
await Assert.That(date.Year).IsEqualTo(2025);
await Assert.That(date.Month).IsEqualTo(1);
}
Data-driven tests
[Test]
[Arguments("user1@test.com", "ValidPassword123")]
[Arguments("user2@test.com", "AnotherPassword456")]
[Arguments("admin@test.com", "AdminPass789")]
public async Task User_Login_Should_Succeed(string email, string password)
{
var result = await authService.LoginAsync(email, password);
await Assert.That(result.IsSuccess).IsTrue();
}
// Matrix — generates a test for every combination (9 total here)
[Test]
[MatrixDataSource]
public async Task Database_Operations_Work(
[Matrix("Create", "Update", "Delete")] string operation,
[Matrix("User", "Product", "Order")] string entity)
{
await Assert.That(await ExecuteOperation(operation, entity))
.IsTrue();
}
Hooks, dependencies, and retry
[Before(Class)]
public static async Task SetupDatabase(ClassHookContext context)
{
await DatabaseHelper.InitializeAsync();
}
[Test]
[MethodDataSource(nameof(GetTestUsers))]
public async Task Register_User(string username, string password) { ... }
[Test, DependsOn(nameof(Register_User))]
[Retry(3)]
public async Task Login_With_Registered_User(string username, string password)
{
// Guaranteed to run after Register_User passes
}
Custom attributes
Extend built-in base classes to create your own skip conditions, retry logic, and more:
public class WindowsOnlyAttribute : SkipAttribute
{
public WindowsOnlyAttribute() : base("Windows only") { }
public override Task<bool> ShouldSkip(TestContext testContext)
=> Task.FromResult(!OperatingSystem.IsWindows());
}
[Test, WindowsOnly]
public async Task Windows_Specific_Feature() { ... }
See the documentation for more examples, including custom retry logic and data sources.
IDE Support
| IDE | Notes |
|---|---|
| Visual Studio 2022 (17.13+) | Works out of the box |
| Visual Studio 2022 (earlier) | Enable "Use testing platform server mode" in Tools > Manage Preview Features |
| JetBrains Rider | Enable "Testing Platform support" in Settings > Build, Execution, Deployment > Unit Testing > Testing Platform |
| VS Code | Install C# Dev Kit and enable "Use Testing Platform Protocol" |
| CLI | Works with dotnet test, dotnet run, and direct execution |
Packages
| Package | Purpose |
|---|---|
TUnit |
Start here — the full framework (Core + Engine + Assertions) |
TUnit.Core |
Shared test library components without an execution engine |
TUnit.Engine |
Execution engine for test projects |
TUnit.Assertions |
Standalone assertions — works with other test frameworks too |
TUnit.Playwright |
Playwright integration with automatic browser lifecycle management |
Migrating from xUnit, NUnit, or MSTest?
The syntax will feel familiar. For example, xUnit's [Fact] becomes [Test], and [Theory] + [InlineData] becomes [Test] + [Arguments]. See the migration guides for full details: xUnit · NUnit · MSTest.
Community
- Documentation — guides, tutorials, and API reference
- GitHub Discussions — questions and ideas welcome
- Issues — bug reports and feature requests
- Changelog
| 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 is compatible. 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 is compatible. 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 is compatible. 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. |
-
.NETStandard 2.0
- Microsoft.Testing.Extensions.CodeCoverage (>= 18.5.1)
- Microsoft.Testing.Extensions.Telemetry (>= 2.1.0)
- Microsoft.Testing.Extensions.TrxReport (>= 2.1.0)
- System.Threading.Tasks.Extensions (>= 4.6.3)
- TUnit.Assertions (>= 1.18.0)
- TUnit.Engine (>= 1.18.0)
-
net10.0
- Microsoft.Testing.Extensions.CodeCoverage (>= 18.5.1)
- Microsoft.Testing.Extensions.Telemetry (>= 2.1.0)
- Microsoft.Testing.Extensions.TrxReport (>= 2.1.0)
- TUnit.Assertions (>= 1.18.0)
- TUnit.Engine (>= 1.18.0)
-
net8.0
- Microsoft.Testing.Extensions.CodeCoverage (>= 18.5.1)
- Microsoft.Testing.Extensions.Telemetry (>= 2.1.0)
- Microsoft.Testing.Extensions.TrxReport (>= 2.1.0)
- TUnit.Assertions (>= 1.18.0)
- TUnit.Engine (>= 1.18.0)
-
net9.0
- Microsoft.Testing.Extensions.CodeCoverage (>= 18.5.1)
- Microsoft.Testing.Extensions.Telemetry (>= 2.1.0)
- Microsoft.Testing.Extensions.TrxReport (>= 2.1.0)
- TUnit.Assertions (>= 1.18.0)
- TUnit.Engine (>= 1.18.0)
NuGet packages (13)
Showing the top 5 NuGet packages that depend on TUnit:
| Package | Downloads |
|---|---|
|
TUnit.Playwright
A .NET Testing Framework |
|
|
Saucery.TUnit
Sorcery for SauceLabs - Unlocking SauceLabs capability |
|
|
Rewrite.Test
Test harness for the automated code refactoring framework OpenRewrite. |
|
|
rbkApiModules.Testing.Core
Package Description |
|
|
CookieCrumble.TUnit
Package Description |
GitHub repositories (31)
Showing the top 20 popular GitHub repositories that depend on TUnit:
| Repository | Stars |
|---|---|
|
MaterialDesignInXAML/MaterialDesignInXamlToolkit
Google's Material Design in XAML & WPF, for C# & VB.Net.
|
|
|
kurrent-io/KurrentDB
KurrentDB is a database that's engineered for modern software applications and event-driven architectures. Its event-native design simplifies data modeling and preserves data integrity while the integrated streaming engine solves distributed messaging challenges and ensures data consistency.
|
|
|
fluentassertions/fluentassertions
A very extensive set of extension methods that allow you to more naturally specify the expected outcome of a TDD or BDD-style unit tests. Targets .NET Framework 4.7, as well as .NET Core 2.1, .NET Core 3.0, .NET 6, .NET Standard 2.0 and 2.1. Supports the unit test frameworks MSTest2, NUnit3, XUnit2, MSpec, and NSpec3.
|
|
|
VerifyTests/Verify
Verify is a snapshot testing tool that simplifies the assertion of complex data models and documents.
|
|
|
Nexus-Mods/NexusMods.App
Home of the development of the Nexus Mods App
|
|
|
wiremock/WireMock.Net
WireMock.Net is a flexible product for stubbing and mocking web HTTP responses using advanced request matching and response templating. Based on WireMock Java, but extended with more functionality.Full documentation can be found at https://wiremock.org/dotnet/.
|
|
|
TNG/ArchUnitNET
A C# architecture test library to specify and assert architecture rules in C# for automated testing.
|
|
|
AwesomeAssertions/AwesomeAssertions
A fork of FluentAssertions controlled by the community.
|
|
|
andrewlock/NetEscapades.AspNetCore.SecurityHeaders
Small package to allow adding security headers to ASP.NET Core websites
|
|
|
erwinkramer/bank-api
The Bank API is a design reference project suitable to bootstrap development for a compliant and modern API.
|
|
|
JasperFx/alba
Easy integration testing for ASP.NET Core applications
|
|
|
Eventuous/eventuous
Event Sourcing library for .NET
|
|
|
thomhurst/ModularPipelines
Write your pipelines in C# !
|
|
|
foxminchan/BookWorm
The practical implementation of Aspire using Microservices, AI-Agents
|
|
|
LightBDD/LightBDD
BDD framework allowing to create easy to read and maintain tests.
|
|
|
SwissLife-OSS/snapshooter
Snapshooter is a snapshot testing tool for .NET Core and .NET Framework
|
|
|
eiriktsarpalis/PolyType
Practical generic programming for .NET
|
|
|
Lyrcaxis/KokoroSharp
Fast local TTS inference engine in C# with ONNX runtime. Multi-speaker, multi-platform and multilingual. Integrate on your .NET projects using a plug-and-play NuGet package, complete with all voices.
|
|
|
Altinn/altinn-studio
Next generation open source Altinn platform and applications.
|
|
|
DamianMorozov/OpenTgResearcher
OpenTgResearcher - tool for analyzing Telegram chats and downloading their content
|
| Version | Downloads | Last Updated |
|---|---|---|
| 1.18.0 | 0 | 3/2/2026 |
| 1.17.54 | 2,050 | 2/27/2026 |
| 1.17.36 | 3,947 | 2/26/2026 |
| 1.17.29 | 2,546 | 2/26/2026 |
| 1.17.25 | 1,877 | 2/25/2026 |
| 1.17.20 | 640 | 2/25/2026 |
| 1.17.11 | 4,913 | 2/24/2026 |
| 1.17.7 | 4,240 | 2/22/2026 |
| 1.17.4 | 1,173 | 2/22/2026 |
| 1.17.0 | 1,060 | 2/22/2026 |
| 1.16.4 | 11,550 | 2/18/2026 |
| 1.16.0 | 1,714 | 2/18/2026 |
| 1.15.11 | 4,422 | 2/18/2026 |
| 1.15.7 | 1,992 | 2/17/2026 |
| 1.15.0 | 9,176 | 2/15/2026 |
| 1.14.0 | 3,286 | 2/14/2026 |
| 1.13.70 | 1,156 | 2/14/2026 |
| 1.13.69 | 791 | 2/14/2026 |
| 1.13.60 | 3,532 | 2/13/2026 |
| 1.13.56 | 3,381 | 2/12/2026 |