xunit.v3.extensions.ordering
0.1.1
See the version list below for details.
dotnet add package xunit.v3.extensions.ordering --version 0.1.1
NuGet\Install-Package xunit.v3.extensions.ordering -Version 0.1.1
<PackageReference Include="xunit.v3.extensions.ordering" Version="0.1.1" />
<PackageVersion Include="xunit.v3.extensions.ordering" Version="0.1.1" />
<PackageReference Include="xunit.v3.extensions.ordering" />
paket add xunit.v3.extensions.ordering --version 0.1.1
#r "nuget: xunit.v3.extensions.ordering, 0.1.1"
#:package xunit.v3.extensions.ordering@0.1.1
#addin nuget:?package=xunit.v3.extensions.ordering&version=0.1.1
#tool nuget:?package=xunit.v3.extensions.ordering&version=0.1.1
xunit.v3.extensions.ordering
Simple ordering extensions for xUnit.net v3.
This package lets you control the execution order of test methods and test collections using a [Order] attribute.
Inspired by Xunit.Extensions.Ordering, but implemented specifically for xUnit v3.
Installation
dotnet add package xunit.v3.extensions.ordering
Usage
Register orderers
Register once in your test project (for example in TestSetup.cs):
using Xunit;
using Xunit.v3;
using Xunit.v3.Extensions.Ordering;
[assembly: CollectionBehavior(DisableTestParallelization = true)]
[assembly: TestCaseOrderer(typeof(OrderedTestCaseOrderer))]
[assembly: TestCollectionOrderer(typeof(OrderedTestCollectionOrderer))]
If collection order matters, parallelization should be disabled. Otherwise xUnit may run collections in parallel and ignore ordering.
Order test methods
using Xunit;
using Xunit.v3.Extensions.Ordering;
public class CheckoutTests
{
[Fact, Order(1)]
public void AddItemToCart() { }
[Fact, Order(2)]
public void ApplyDiscount() { }
[Fact, Order(3)]
public void CompletePayment() { }
}
Runs in order:
AddItemToCart → ApplyDiscount → CompletePayment
Order test collections
Apply [Order] to collection definitions:
[CollectionDefinition("Setup")]
[Order(1)]
public class SetupCollection;
[CollectionDefinition("Tests")]
[Order(2)]
public class TestsCollection;
[CollectionDefinition("Cleanup")]
[Order(3)]
public class CleanupCollection;
Then assign test classes:
[Collection("Setup")]
public class DatabaseSetupTests
{
[Fact, Order(1)]
public void CreateSchema() { }
[Fact, Order(2)]
public void SeedData() { }
}
[Collection("Tests")]
public class BusinessLogicTests
{
[Fact, Order(1)]
public void ValidateOrder() { }
}
[Collection("Cleanup")]
public class TeardownTests
{
[Fact, Order(1)]
public void DropDatabase() { }
}
Execution order:
Setup → Tests → Cleanup
Behavior
- ordering is ascending (
Order(1)runs beforeOrder(2)) - negative values are allowed
- tests without
[Order]default to0 - same order values are resolved by name (to keep execution deterministic)
Limitations
- ordering test classes inside a collection is not supported (xUnit v3 does not expose a public API for this)
- this package does not replace the test framework or runner
Migration notes
If you used Xunit.Extensions.Ordering (v2):
[Order]works the same- registration now uses
typeof(...)instead of strings - assembly fixtures are handled natively by xUnit v3
| Before (v2) | After (v3) |
|---|---|
[Order(1)] on methods/classes |
[Order(1)] — same |
[assembly: TestCaseOrderer("...", "...")] |
[assembly: TestCaseOrderer(typeof(OrderedTestCaseOrderer))] |
[assembly: TestCollectionOrderer("...", "...")] |
[assembly: TestCollectionOrderer(typeof(OrderedTestCollectionOrderer))] |
| Custom assembly fixtures | Use xUnit v3 native assembly fixtures |
License
MIT
Links
- GitHub Repository
- NuGet Package (coming soon)
| 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. |
-
.NETStandard 2.0
- xunit.v3.extensibility.core (>= 3.2.2)
NuGet packages
This package is not used by any NuGet packages.
GitHub repositories
This package is not used by any popular GitHub repositories.