Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Readable assertion messages on failure. #155

Merged
226 changes: 112 additions & 114 deletions src/FsUnit.MsTestUnit/FsUnit.fs
Original file line number Diff line number Diff line change
@@ -1,119 +1,117 @@
module FsUnit.MsTest

open System
open Microsoft.VisualStudio.TestTools.UnitTesting
open NHamcrest
open NHamcrest.Core
open System.Collections

let inline private assertThat(actual, matcher:IMatcher<'a>) =
if not (matcher.Matches(actual)) then
let description = new StringDescription()
matcher.DescribeTo(description)
let mismatchDescription = new StringDescription()
matcher.DescribeMismatch(actual, mismatchDescription)
raise (new AssertFailedException(sprintf "%s %s" (description.ToString()) (mismatchDescription.ToString())))

#if NETSTANDARD1_6
type Assert with
static member That'<'a> (actual, matcher:IMatcher<'a>) =
assertThat(actual, matcher)
#else
type Assert with
static member That<'a> (actual, matcher:IMatcher<'a>) =
assertThat(actual, matcher)
#endif

let inline should (f : 'a -> ^b) x (y : obj) =
let c = f x
let y =
match y with
| :? (unit -> unit) as assertFunc -> box assertFunc
| _ -> y
if box c = null then
module FsUnit.MsTest

open System
open Microsoft.VisualStudio.TestTools.UnitTesting
open NHamcrest
open NHamcrest.Core
open System.Collections

let inline private assertThat(actual, matcher:IMatcher<'a>) =
if not (matcher.Matches(actual)) then
let description = new StringDescription()
matcher.DescribeTo(description)
raise (new AssertFailedException(sprintf "%s %s" (description.ToString()) (sprintf "was %A" actual)))
CaptnCodr marked this conversation as resolved.
Show resolved Hide resolved

#if NETSTANDARD1_6
type Assert with
static member That'<'a> (actual, matcher:IMatcher<'a>) =
assertThat(actual, matcher)
#else
type Assert with
static member That<'a> (actual, matcher:IMatcher<'a>) =
assertThat(actual, matcher)
#endif

let inline should (f : 'a -> ^b) x (y : obj) =
let c = f x
let y =
match y with
| :? (unit -> unit) as assertFunc -> box assertFunc
| _ -> y
if isNull (box c) then
assertThat(y, Is.Null())
else
assertThat(y, c)


let inline shouldFail (f:unit->unit) =
let failed =
try
f()
false
with
| _ -> true
if not failed then
raise (new AssertFailedException("Method should fail"))


let equal expected = CustomMatchers.equal expected

let equivalent expected =
CustomMatchers.equivalent (fun e a -> CollectionAssert.AreEquivalent(e, a)) expected

let equalWithin (tolerance:obj) (expected:obj) = CustomMatchers.equalWithin tolerance expected

let not' (expected:obj) = CustomMatchers.not' expected

let throw (t:Type) = CustomMatchers.throw t

let throwWithMessage (m:string) (t:Type) = CustomMatchers.throwWithMessage m t

let be = CustomMatchers.be

let Null = CustomMatchers.Null

let Empty = CustomMatchers.Empty

let EmptyString = CustomMatchers.EmptyString

let NullOrEmptyString = CustomMatchers.NullOrEmptyString

let True = CustomMatchers.True

let False = CustomMatchers.False

let NaN = CustomMatchers.NaN

let unique = CustomMatchers.unique

let sameAs expected = CustomMatchers.sameAs expected

let greaterThan (expected:obj) = CustomMatchers.greaterThan expected

let greaterThanOrEqualTo (expected:obj) = CustomMatchers.greaterThanOrEqualTo expected

let lessThan (expected:obj) = CustomMatchers.lessThan expected

let lessThanOrEqualTo (expected:obj) = CustomMatchers.lessThanOrEqualTo expected

let endWith (expected:string) = CustomMatchers.endWith expected

let startWith (expected:string) = CustomMatchers.startWith expected

let haveSubstring (expected:string) = CustomMatchers.haveSubstring expected

let ofExactType<'a> = CustomMatchers.ofExactType<'a>

let instanceOfType<'a> = CustomMatchers.instanceOfType<'a>

let contain expected = CustomMatchers.contain expected

let haveLength n = CustomMatchers.haveLength n

let haveCount n = CustomMatchers.haveCount n

let matchList = CustomMatchers.matchList

let choice = CustomMatchers.choice

let ascending = CustomMatchers.ascending

let descending = CustomMatchers.descending

let inRange min max = CustomMatchers.inRange min max

assertThat(y, c)
let inline shouldFail (f:unit->unit) =
let failed =
try
f()
false
with
| _ -> true
if not failed then
raise (new AssertFailedException("Method should fail"))
let equal expected = CustomMatchers.equal expected
let equivalent expected =
CustomMatchers.equivalent (fun e a -> CollectionAssert.AreEquivalent(e, a)) expected
let equalWithin (tolerance:obj) (expected:obj) = CustomMatchers.equalWithin tolerance expected
let not' (expected:obj) = CustomMatchers.not' expected
let throw (t:Type) = CustomMatchers.throw t
let throwWithMessage (m:string) (t:Type) = CustomMatchers.throwWithMessage m t
let be = CustomMatchers.be
let Null = CustomMatchers.Null
let Empty = CustomMatchers.Empty
let EmptyString = CustomMatchers.EmptyString
let NullOrEmptyString = CustomMatchers.NullOrEmptyString
let True = CustomMatchers.True
let False = CustomMatchers.False
let NaN = CustomMatchers.NaN
let unique = CustomMatchers.unique
let sameAs expected = CustomMatchers.sameAs expected
let greaterThan (expected:obj) = CustomMatchers.greaterThan expected
let greaterThanOrEqualTo (expected:obj) = CustomMatchers.greaterThanOrEqualTo expected
let lessThan (expected:obj) = CustomMatchers.lessThan expected
let lessThanOrEqualTo (expected:obj) = CustomMatchers.lessThanOrEqualTo expected
let endWith (expected:string) = CustomMatchers.endWith expected
let startWith (expected:string) = CustomMatchers.startWith expected
let haveSubstring (expected:string) = CustomMatchers.haveSubstring expected
let ofExactType<'a> = CustomMatchers.ofExactType<'a>
let instanceOfType<'a> = CustomMatchers.instanceOfType<'a>
let contain expected = CustomMatchers.contain expected
let haveLength n = CustomMatchers.haveLength n
let haveCount n = CustomMatchers.haveCount n
let matchList = CustomMatchers.matchList
let choice = CustomMatchers.choice
let ascending = CustomMatchers.ascending
let descending = CustomMatchers.descending
let inRange min max = CustomMatchers.inRange min max
let ofCase case = CustomMatchers.ofCase case

let supersetOf expected = CustomMatchers.supersetOf expected
Expand Down
12 changes: 4 additions & 8 deletions src/FsUnit.NUnit/FsUnit.fs
Original file line number Diff line number Diff line change
@@ -1,14 +1,10 @@
// TODO : Add license header
namespace FsUnit

namespace FsUnit

open System
open System.Diagnostics
open NUnit.Framework
open NUnit.Framework.Constraints
open CustomConstraints

//
[<AutoOpen>]
module TopLevelOperators =

Expand Down Expand Up @@ -40,7 +36,7 @@ module TopLevelOperators =
match y with
| :? (unit -> unit) -> box (TestDelegate(y :?> unit -> unit))
| _ -> y
if box c = null then
if isNull (box c) then
Assert.That(y, Is.Null)
else
Assert.That(y, c)
Expand Down Expand Up @@ -90,8 +86,8 @@ module TopLevelOperators =

let descending = Is.Ordered.Descending

let not' x =
if box x = null then NotConstraint(Null) else NotConstraint(x)
let not' x =
if isNull (box x) then NotConstraint(Null) else NotConstraint(x)

let inRange min max = RangeConstraint(min, max)

Expand Down
8 changes: 3 additions & 5 deletions src/FsUnit.Xunit/FsUnit.fs
Original file line number Diff line number Diff line change
Expand Up @@ -10,21 +10,19 @@ type MatchException (expected, actual, userMessage) =
inherit AssertActualExpectedException(expected, actual, userMessage)

type Xunit.Assert with
static member That<'a> (actual, matcher:IMatcher<'a>) =
static member That<'a> (actual, matcher: IMatcher<'a>) =
if not (matcher.Matches(actual)) then
let description = new StringDescription()
matcher.DescribeTo(description)
let mismatchDescription = new StringDescription()
matcher.DescribeMismatch(actual, mismatchDescription)
raise (new MatchException(description.ToString(), mismatchDescription.ToString(), null))
raise (new MatchException(description.ToString(), (sprintf "was %A" actual), null))

let inline should (f : 'a -> ^b) x (y : obj) =
let c = f x
let y =
match y with
| :? (unit -> unit) as assertFunc -> box assertFunc
| _ -> y
if box c = null then
if isNull (box c) then
Assert.That(y, Is.Null())
else
Assert.That(y, c)
Expand Down