2017-03-19 13:35:46 +00:00
|
|
|
namespace OpenTK.Tests
|
|
|
|
|
|
|
|
open Xunit
|
|
|
|
open FsCheck
|
|
|
|
open FsCheck.Xunit
|
|
|
|
open System
|
|
|
|
open OpenTK
|
|
|
|
|
|
|
|
[<AutoOpen>]
|
2017-06-01 19:12:59 +00:00
|
|
|
module private AssertHelpers =
|
2017-03-19 13:35:46 +00:00
|
|
|
[<Literal>]
|
2017-06-02 18:44:30 +00:00
|
|
|
let private BitAccuracy = 13
|
2017-06-01 19:12:59 +00:00
|
|
|
|
2017-03-19 13:35:46 +00:00
|
|
|
let approxEq a b = MathHelper.ApproximatelyEqual(a,b,BitAccuracy)
|
|
|
|
|
|
|
|
/// We use a full type here instead of a module, as the overloading semantics are more suitable for our desired goal.
|
|
|
|
[<Sealed>]
|
2017-06-01 19:12:59 +00:00
|
|
|
type internal Assert =
|
|
|
|
|
|
|
|
static member ApproximatelyEqual(a : Vector2,b : Vector2) =
|
2017-03-19 13:35:46 +00:00
|
|
|
if not <| approxEq a.X b.X && approxEq a.Y b.Y then raise <| new Xunit.Sdk.EqualException(a,b)
|
2017-06-01 19:12:59 +00:00
|
|
|
|
|
|
|
static member ApproximatelyEqual(a : Vector3,b : Vector3) =
|
2017-03-19 13:35:46 +00:00
|
|
|
if not <| approxEq a.X b.X && approxEq a.Y b.Y && approxEq a.Z b.Z then raise <| new Xunit.Sdk.EqualException(a,b)
|
2017-06-01 19:12:59 +00:00
|
|
|
|
|
|
|
static member ApproximatelyEqual(a : Vector4,b : Vector4) =
|
|
|
|
if not <| approxEq a.X b.X && approxEq a.Y b.Y && approxEq a.Z b.Z && approxEq a.W b.W then
|
2017-03-19 13:35:46 +00:00
|
|
|
raise <| new Xunit.Sdk.EqualException(a,b)
|
2017-06-01 19:12:59 +00:00
|
|
|
|
|
|
|
static member ApproximatelyEqual(a : float32,b : float32) =
|
2017-03-19 13:35:46 +00:00
|
|
|
if not <| approxEq a b then raise <| new Xunit.Sdk.EqualException(a,b)
|
2017-06-02 11:48:29 +00:00
|
|
|
|
|
|
|
|
|
|
|
static member ThrowsIndexExn(f:unit -> unit) = Assert.Throws<IndexOutOfRangeException>(f) |> ignore
|