FiniteModelChecker 1.0.0
See the version list below for details.
dotnet add package FiniteModelChecker --version 1.0.0
NuGet\Install-Package FiniteModelChecker -Version 1.0.0
<PackageReference Include="FiniteModelChecker" Version="1.0.0" />
paket add FiniteModelChecker --version 1.0.0
#r "nuget: FiniteModelChecker, 1.0.0"
// Install FiniteModelChecker as a Cake Addin #addin nuget:?package=FiniteModelChecker&version=1.0.0 // Install FiniteModelChecker as a Cake Tool #tool nuget:?package=FiniteModelChecker&version=1.0.0
Finite Model Checker
This is a finite model checker for C#. Use it to exhaustively explore all possible sequences of operations against your codebase. Instead of arduously writing unit tests to perform a small series of operations, just define the set of all possible operations and let this library get to work! Example use cases:
- Exhaustively test your custom data structure against reads and writes
- Effectively explore the state space of your concurrency control code
- Simulate events in a multi-replica mockup of your system
Forked from Azure/RingMaster; I wrote this tool at Microsoft to test some particularly tricky serialization code for reducing memory usage.
How To Build
- Install .NET Core
- Clone the repo
- Run
dotnet build
from the root of the repo
How To Use
In order to model-check your code, you must define the following:
- The set of initial states
- The set of possible state transitions
- The set of safety invariants: things which you want to always be true
The model-checker will then perform a breadth-first search from your initial states using the state transitions, checking the invariants in each state and reporting a full error trace if an invariant fails to hold. This means your model must generate only a finite number of states, as otherwise the model-checker will run forever.
For a simple example, you can see an implementation of the water jugs puzzle from Die Hard 3 in the Tests directory.
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. |
.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
- No dependencies.
NuGet packages
This package is not used by any NuGet packages.
GitHub repositories
This package is not used by any popular GitHub repositories.