FluentAssertions 2.0.1

.NET Framework 3.5
There is a newer version of this package available.
See the version list below for details.
NuGet\Install-Package FluentAssertions -Version 2.0.1
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.
dotnet add package FluentAssertions --version 2.0.1
<PackageReference Include="FluentAssertions" Version="2.0.1" />
For projects that support PackageReference, copy this XML node into the project file to reference the package.
paket add FluentAssertions --version 2.0.1
#r "nuget: FluentAssertions, 2.0.1"
#r directive can be used in F# Interactive, C# scripting and .NET Interactive. Copy this into the interactive tool or source code of the script to reference the package.
// Install FluentAssertions as a Cake Addin
#addin nuget:?package=FluentAssertions&version=2.0.1

// Install FluentAssertions as a Cake Tool
#tool nuget:?package=FluentAssertions&version=2.0.1

A very extensive set of extension methods that allow you to more naturally specify the expected outcome of a TDD or
     BDD-style unit test. Runs on .NET 3.5, 4.0 and 4.5 (Desktop and Windows Store), Silverlight 4 and 5 and Windows Phone 7.5. Supports the unit test frameworks NUnit, XUnit, MBUnit, Gallio and MSpec.

Product Versions
.NET Framework net35 net40 net403 net45 net451 net452 net46 net461 net462 net463 net47 net471 net472 net48
Silverlight sl4 sl4-wp71 sl5
WinRT winrt45
Compatible target framework(s)
Additional computed target framework(s)
Learn more about Target Frameworks and .NET Standard.

This package has no dependencies.

NuGet packages (383)

Showing the top 5 NuGet packages that depend on FluentAssertions:

Package Downloads
FluentAssertions.Json The ID prefix of this package has been reserved for one of the owners of this package by NuGet.org.

Fluent Assertions extensions for Newtonsoft.Json

Akka.TestKit

You need a Akka.TestKit.* package! Add the one appropriate for the test framework you use instead. For example: Akka.TestKit.Xunit or Akka.TestKit.VsTest. This package only contains base functionality for writing tests for the Akka.NET framework.

FluentValidation.Validators.UnitTestExtension

A unit test library for .NET that allows you to build tests for FluentValidation rules in easy way.

VirtoCommerce.SearchModule.Core

Package Description

FluentAssertions.AspNetCore.Mvc

Fluent Assertions extensions for ASP.NET Core MVC.

GitHub repositories (560)

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

Repository Stars
App-vNext/Polly
Polly is a .NET resilience and transient-fault-handling library that allows developers to express policies such as Retry, Circuit Breaker, Timeout, Bulkhead Isolation, and Fallback in a fluent and thread-safe manner. From version 6.0.1, Polly targets .NET Standard 1.1 and 2.0+.
dotnet/runtime
.NET is a cross-platform runtime for cloud, mobile, desktop, and IoT apps.
jasontaylordev/CleanArchitecture
Clean Architecture Solution Template for .NET 6
coding-horror/basic-computer-games
An updated version of the classic "Basic Computer Games" book, with well-written examples in a variety of common MEMORY SAFE, SCRIPTING programming languages. See https://coding-horror.github.io/basic-computer-games/
IdentityServer/IdentityServer4
OpenID Connect and OAuth 2.0 Framework for ASP.NET Core
Version Downloads Last updated
6.7.0 6,423,623 5/18/2022
6.6.0 3,554,239 4/3/2022
6.5.1 4,829,200 2/11/2022
6.5.0 131,678 2/10/2022
6.4.0 2,325,913 1/22/2022
6.3.0 2,085,369 1/1/2022
6.2.0 7,022,300 10/25/2021
6.1.0 6,688,844 8/22/2021
6.0.0 1,097,853 8/13/2021
6.0.0-beta0003 14,149 8/11/2021
6.0.0-beta0002 6,646 8/5/2021
6.0.0-beta0001 120,749 6/1/2021
6.0.0-alpha0002 365,303 1/7/2021
6.0.0-alpha0001 413,035 7/24/2020
5.10.3 56,981,089 3/21/2020
5.10.2 5,285,909 2/9/2020
5.10.0 4,534,427 1/2/2020
5.9.0 10,967,840 8/28/2019
5.8.0 1,631,848 8/9/2019
5.7.0 6,482,737 6/8/2019
5.6.0 11,200,013 1/11/2019
5.5.3 3,155,772 11/20/2018
5.5.1 250,311 11/16/2018
5.4.2 3,323,592 9/14/2018
5.4.1 4,805,680 6/20/2018
5.4.0 513,412 6/13/2018
5.3.2 771,065 5/30/2018
5.3.0 2,086,978 4/19/2018
5.2.0 1,499,616 3/15/2018
5.1.2 1,139,952 2/19/2018
5.1.1 194,432 2/14/2018
5.0.0 1,487,252 2/4/2018
4.19.4 7,506,589 8/24/2017
4.19.3 1,532,204 7/4/2017
4.19.2 3,670,377 3/8/2017
4.19.0 1,310,229 2/4/2017
4.18.0 1,792,371 12/4/2016
4.17.0 812,850 11/9/2016
4.16.0 328,055 10/26/2016
4.15.0 289,888 10/11/2016
4.14.0 927,591 9/5/2016
4.13.1 98,057 9/1/2016
4.13.0 460,088 8/2/2016
4.12.0 817,284 7/15/2016
4.11.0 246,019 7/6/2016
4.10.0 21,938 7/5/2016
4.9.1 231,029 6/23/2016
4.9.0 175,372 6/13/2016
4.8.0 85,967 6/7/2016
4.7.0 59,667 6/6/2016
4.6.3 326,979 5/24/2016
4.6.2 44,088 5/22/2016
4.6.1 135,378 5/13/2016
4.5.0 283,882 4/25/2016
4.4.0 191,317 4/17/2016
4.3.2 89,241 4/3/2016
4.3.1 5,463 4/1/2016
4.3.0 74,002 3/31/2016
4.2.2 631,474 2/5/2016
4.2.1 347,265 1/10/2016
4.2.0 211,240 1/8/2016
4.1.1 168,439 12/13/2015
4.1.0 358,835 11/24/2015
4.0.1 394,185 10/21/2015
4.0.0 549,759 8/24/2015
4.0.0-beta0001 3,265 8/7/2015
3.5.0 339,310 8/2/2015
3.4.1 318,158 7/3/2015
3.4.0 114,133 6/22/2015
3.3.0 875,183 2/18/2015
3.2.2 250,473 12/12/2014
3.2.1 425,472 9/11/2014
3.1.229 238,709 7/29/2014
3.0.107 349,611 4/30/2014
2.2.0 648,309 12/30/2013
2.1.0 262,305 8/23/2013
2.0.1 283,589 3/3/2013
2.0.0.1 123,886 10/15/2012
1.7.1.1 88,641 3/24/2012
1.7.0 10,002 1/13/2012
1.6.0 15,351 10/31/2011
1.5.0 10,614 6/29/2011
1.4.0 5,979 3/14/2011
1.3.0.1 29,031 1/15/2011

What's new in 2.0.1
     * Small bug-fix to better intercept and/or prevent exceptions while scanning for methods annotated with [ValueFormatter]
     
     What are the major features
     * Added support for .NET 4.5, Windows Phone 7.5 and .NET for Windows Store Apps
     * Added support for MBUnit and the Gallio framework
     * Added a completely new extensible API for comparing two objects graph for equivalence that will replace the object.ShouldHave() API in the future (issue 11841).

     What's new for collections
     * Added (Not)BeInAscendingOrder() and (Not)BeInDescendingOrder() (issue 12103)
     * Added IntersectWith(otherCollection) and NotIntersectWith(otherCollection) (issue 12248)
     * ContainInOrder() now has an overload that only takes a params object[] argument to support a more fluent syntax in case you don't specify the reason (issue 12313).
     * Added ContainSingle(Expression<Func<T, bool=""> predicate>) that asserts there is only a single element in the collection that matches the specified predicate (issue 12313).
     * Added support for a lambda that is used for checking the equality of two collections (issue 11925).
     * Fixed a bug that occurs when two collections are compared for equality but the collection contains null (issue 12296)

     What's new for strings
     * When strings differ in length, it will report the expected and actual lengths as part of the failure messages (issue 12422)
     * An ArgumentOutOfRangeException was thrown when asserting a string started with a specific string, but the first string was shorter than the expected string (issue 12293)

     What's new for numbers
     * Added support for using Should().Be() on nullable numeric types (issue 11837)
     * Added BeOneOf() to verify that the value matching one of the provided values (issue 12016).
     * Added support for (nullable) decimals
     * BePositive() and BeNegative() now also work for floats and doubles (issue 11946)

     What's new for dates and times
     * Added NotBe()
     * Added BeOneOf() to verify that the value matching one of the provided values (issue 12016).
     * Added BeCloseTo() to assert that a datetime is within a specified number of milliseconds from another datetime value. Usefull for example when your database truncates datetime values (issue 12070).
     * If a DateTime value has milliseconds then they will be displayed in an assertion failure message (issue 12072).

     What's new for comparing object graphs
     * You can now apply the property equality comparisons to entire collections of objects. It doesn't matter what kind of collections types you use, as long as they contain the same number of objects which properties are the same (issue 11743).
     * Included the index of the mismatching object when comparing a collection for structural equality
     * An exception was thrown when comparing the properties of an object, and there were cyclic references. You can now configure if you want this to be ignored.
     * Added support for comparing references to an interface rather than concrete types (issue 11840).
     * Write-only properties are ignored (issue 11808)
     * Fixed a stack overflow exception when formatting an object graph containing static cyclic references.
     * Fixed an exception that was thrown when formatting an object graph where one of the properties threw an exception.
     * Added support for comparing two anonymous types using SharedProperties() (issue 11886).
     * The name of a DateTime property was not included in the error message when AllProperties() failed on that property

     What's new for types
     * Added the AllTypes class with a static method From(Assembly assembly) as a wrapper around the Types extension method on Assembly (issue 12186). This allows for a more fluent syntax like AllTypes.From(assembly).ThatImplement<SomeInterface>().Should().BeDecoratedWith<SomeAttribute>();
     * Added support for asserting the properties of an attribute have a specific value (issue 12186).

     What other improvements are new
     * Fixed an exception when asserting equality of dictionaries that contain nulls (issue 12004).
     * The NuGet package will automatically add references to System.Xml and System.Xml.Linq
     * Implemented ShouldThrow<TException>() for Func<Task>, to support working with async methods (issue 12148)
     * Improved several error messages in XDocument- and XElementAssertions
     * All overloads that take a reason have been removed and replaced with optional parameter
     * Allowed ShouldRaisePropertyChangeFor(null) to verify that the INotifyPropertyChanged was raised for all properties.
     * The list of ValueFormatters on the Verification class can be changed to insert a custom formatter.
     * Introduced a mechanism to override the way FA formats objects in failure message by annotating a static method with the [ValueFormatter] attribute (issue 12364).
     * Introduced a mechanism so that the failure message of custom extensions can specify the {context} tag.
     * NuGet package is now based on NuGet 2.0.

     Breaking changes
     * The FluentAssertions.Assertions namespace no longer exists so that all extension methods are always available through the FluentAssertions namespace. Just use a global search-replace to remove all those usage statements.
     * Many of the assertion classes have moved into dedicated namespaces. You might have to fix any code that inherits from those classes.
     * Remove the obsolete Verify() methods from the Verification class