NFluent 2.3.0

There is a newer version of this package available.
See the version list below for details.
dotnet add package NFluent --version 2.3.0
NuGet\Install-Package NFluent -Version 2.3.0
This command is intended to be used within the Package Manager Console in Visual Studio, as it uses the NuGet module's version of Install-Package.
<PackageReference Include="NFluent" Version="2.3.0" />
For projects that support PackageReference, copy this XML node into the project file to reference the package.
paket add NFluent --version 2.3.0
#r "nuget: NFluent, 2.3.0"
#r directive can be used in F# Interactive and Polyglot Notebooks. Copy this into the interactive tool or source code of the script to reference the package.
// Install NFluent as a Cake Addin
#addin nuget:?package=NFluent&version=2.3.0

// Install NFluent as a Cake Tool
#tool nuget:?package=NFluent&version=2.3.0

NFluent is an ergonomic check library which aims to fluent your .NET TDD experience (based on simple Check.That() check statements). NFluent aims your tests to be fluent to write (with an happy 'dot' auto completion experience), fluent to read (i.e. as close as possible to plain English expression), but also fluent to troubleshoot, in a less-error-prone way comparing to the classical .NET test frameworks. NFluent is directly, but also freely, inspired by the awesome Java FEST fluent check/reflection library (

Product 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 netcoreapp1.0 was computed.  netcoreapp1.1 was computed.  netcoreapp2.0 was computed.  netcoreapp2.1 was computed.  netcoreapp2.2 was computed.  netcoreapp3.0 was computed.  netcoreapp3.1 was computed. 
.NET Standard netstandard1.3 is compatible.  netstandard1.4 was computed.  netstandard1.5 was computed.  netstandard1.6 was computed.  netstandard2.0 is compatible.  netstandard2.1 was computed. 
.NET Framework net20 is compatible.  net30 is compatible.  net35 is compatible.  net40 is compatible.  net403 was computed.  net45 is compatible.  net451 was computed.  net452 was computed.  net46 was computed.  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 tizen30 was computed.  tizen40 was computed.  tizen60 was computed. 
Universal Windows Platform uap was computed.  uap10.0 was computed. 
Xamarin.iOS xamarinios was computed. 
Xamarin.Mac xamarinmac was computed. 
Xamarin.TVOS xamarintvos was computed. 
Xamarin.WatchOS xamarinwatchos was computed. 
Compatible target framework(s)
Included target framework(s) (in package)
Learn more about Target Frameworks and .NET Standard.

This package has no dependencies.

NuGet packages (13)

Showing the top 5 NuGet packages that depend on NFluent:

Package Downloads

NFluent checks for checking HttpResponseMessages.


Iago is a tool to write bdd like tests in kre. use `iago.runner` to execute your tests


A library for writing flexible and easy to maintain acceptance tests


multi dimension dictionary with expiration mechanism for cache invalidation


Package pour faciliter la mise en place de tests.

GitHub repositories (15)

Showing the top 5 popular GitHub repositories that depend on NFluent:

Repository Stars
More than a ReClass port to the .NET platform.
WireMock.Net is a flexible product for stubbing and mocking web HTTP responses using advanced request matching and response templating. Based on the functionality from, but extended with more functionality.
The FileHelpers are a free and easy to use .NET library to read/write data from fixed length or delimited records in files, strings or streams
This repository was deprecated, use:
Entity Component System framework aiming for syntax and usage simplicity with maximum performance for game development.
Version Downloads Last updated
3.0.4 4,854 3/19/2024
3.0.3 18,731 1/12/2024
3.0.3-beta 457 12/13/2023 8,600 12/12/2023 1,351 10/13/2023 65,559 6/9/2023 22,836 5/6/2023 10,329 3/3/2022 715 2/27/2022 721 2/27/2022 710 2/24/2022
2.8.0 472,021 2/4/2022
2.7.2 257,752 4/8/2021
2.7.1 96,259 12/29/2020
2.7.0 310,364 2/11/2020
2.6.0 207,064 8/19/2019
2.5.0 165,471 3/12/2019
2.4.0 116,405 10/2/2018
2.3.1 90,934 6/12/2018
2.3.0 2,329 6/9/2018
2.2.0 89,294 2/10/2018
2.1.1 28,294 1/5/2018
2.1.0 12,327 12/10/2017
2.0.0 64,028 6/27/2017
2.0.0-alpha-44 2,494 5/10/2017
1.3.1 227,829 7/28/2014
1.2.0 9,231 6/16/2014
1.1.0 5,347 2/14/2014
1.0.0 4,966 12/31/2013
0.11.0 2,396 11/26/2013
0.9.0 2,432 8/6/2013
0.8.0 2,303 7/6/2013
0.7.0 2,123 6/4/2013
0.6.0 2,081 5/19/2013
0.5.0 2,106 4/21/2013

## V 2.3.0


### Main feature: redesigned extensibility

One of the fundamental features of NFluent is that you can add your own checks.

Articles explained how to do that, but syntax was still too cumbersome

for our taste. This version brings major improvements detailed here:

* Simplified support for creating custom checks thanks to new helper methods

and classes (see

* Customization of error reporting: by default, any check failure is reported

by raising an exception. You can now provide your own reporting system. You need to provide an implementation

of IErrorReporter interface, and specify you want to use it by setting the Check.Reporter interface.

### Other New features(s)

* IsNullOrWhiteSpace: checks if a string is null, empty or contains only white space(s).

* IReadOnlyDictionary (_Net 4.5+_)

* ContainsKey, ContainsValue, ContainsPair are supported.

* async method/delegates

* Check.ThatCode now supports _async_ methods/delegates transparently.

* Check expression now provides the result as a string. I.e Check.That(true).IsTrue().ToString() returns "Success".

* New check: IsDefaultValue, which fails if the sut is not the default value for its type: null for ref types, 0 for value types.

* New check: ContainsNoDuplicateItem for enumerable, that fails of it contains a dupe.

* New check: IsEquivalentTo for enumerable, that checks if its contents match an expected content, disregarding order.

* New check: DoesNotContainNull for enumerable, that fails if an entry is null.

* New check: IsAnInstanceOfOneOf that checks if the sut is of one of exptected types.

* New check: IsNotAnInstanceOfThese that checks if the sut type is different from a list of forbidden types.

* New check: DueToAnyFrom(...) that checks that an exception has been triggered by another exception from a list of possible types.

### Fixes

* Check.ThatCode(...).Not.Throws\<T\>() may throw an InvalidCastException when thrown exception is not T.

* Extension checks to Throw\<\>, ThrowType or ThrowAny raise an exception when used with Not as it does not make sense.

* Which() raises an exception when used on a negated check (Not).

* Fix exception when using Considering and indexed properties.

* Fix loss of type when using Contains and ContainsExactly. This restores fluentness for IEnumerable<T> types.

Fixed error messages for double (and float) equality check that reported checked value in place of the expected one.

* Fixed error messages for Check.That(TimeSpan).IsGreaterThan

* False positive whith Considering() or HasFieldsWithSameValues when haing ints and enum attributes with the same value.

### Changes

* Improved error messages

* ContainsOnlyElementsThatMatch: now provides the index and value of the first failing value.

* IsOnlyMadeOf: improved error messages

* DateTime checks: revamped all messages

* Enum: error message on enum types now use 'enum' instead of 'value'.

* IsInstanceOf: be more specific regarding types

* Considering()...IsNull/IsNotNull: error messages specify member triggering the failure.

* Breaking

* Added automatic conversion between decimal and other numerical types. Check.That(100M).IsEqualTo(100) no longer fails.

* Removed Failure method from IChecker interface

### GitHub Issues

* #228, #227, #222, #223, #217, #230, #232,

* #236, #238, #242, #243, #244, #245, #246,

* #231, #247, #161, #249


## V 2.2.0


Flexible property and field based comparison is now available. Examples:

* Check.That(sut)**.Considering().Public.Properties**.IsEqualTo(expected);

* Check.That(sut)**.Considering().Public.Fields.And.Public.Properties**.IsEqualTo(expected);

* Check.That(sut)**.Considering().Public.Fields.Excluding("coordX", "child.address")**.IsEqualTo(expected);

Syntax is:

* Check.That(sut)**.Considering().(Public|NonPublic|All).(Fields.Properties)[.And.(Public|NonPublic|All).(Fields.Properties)][Excluding("fielda", "sub.fieldb")]**.IsEqualTo(expected);

* **Considering()** is supported by: _IsEqualTo(), IsNotEqualTo(), AsSameValueAs(), HasDifferentValueThan(), IsInstanceOf\<type\>()_ [checks if fields/properties are present],

_IsNotInstanceOf\<type\>()_,  _HasSameValueAs()_, _IsSameReferenceAs(), _IsDistinctFrom()_, _HasDifferentValueThan()_

### New feature(s)

* **Object**

* New check **IsInstanceOfType(Type type)** which is equivalent to *IsInstanceOf\<type\>()*, in a non generic form for parameterized tests.

* New check **IsNoInstanceOfType(Type type)** which is equivalent to *IsNotInstanceOf\<type\>()*, in a non generic form for parameterized tests.

* New check **InheritsFromType(Type type)** which is equivalent to *InheritsFrom\<type\>()*, in a non generic form for parameterized tests.

* **Enum**

- New check **HasFlag(xxx)** that checks if a flag is present in an enum value.

* **Code**

* New check **ThrowsType(Type type)** which is equivalent to *Throws\<type\>*, in a non generic form for parameterized tests.

### Changes

* Improved error messages for missing fields(and properties) for reflection based checks.

### Fixes

* Fix issue with overloaded member/properties for HasFieldswithSameValues(...) (#219)

### GitHub Issues

* #219, #218, #216, #215, #214, #121