Returns a TripleEqualsInvocationOnInterval[T]
, given an Interval[T]
, to facilitate
the “<left> should !== (<pivot> +- <tolerance>)
”
syntax of Matchers
.”“
Returns a TripleEqualsInvocationOnInterval[T]
, given an Interval[T]
, to facilitate
the “<left> should !== (<pivot> +- <tolerance>)
”
syntax of Matchers
.
the Interval[T]
against which to compare the left-hand value
a TripleEqualsInvocationOnInterval
wrapping the passed Interval[T]
value, with
expectingEqual
set to false
.
Returns a TripleEqualsInvocation[Null]
, given a null
reference, to facilitate
the “<left> should !== null
” syntax
of Matchers
.”“
Returns a TripleEqualsInvocation[Null]
, given a null
reference, to facilitate
the “<left> should !== null
” syntax
of Matchers
.
a null reference
a TripleEqualsInvocation
wrapping the passed null
value, with expectingEqual
set to false
.
Returns a TripleEqualsInvocation[T]
, given an object of type T
, to facilitate
the “<left> should !== <right>
” syntax
of Matchers
.”“
Returns a TripleEqualsInvocation[T]
, given an object of type T
, to facilitate
the “<left> should !== <right>
” syntax
of Matchers
.
the right-hand side value for an equality assertion
a TripleEqualsInvocation
wrapping the passed right value, with expectingEqual
set to false
.
Returns a TripleEqualsInvocationOnInterval[T]
, given an Interval[T]
, to facilitate
the “<left> should === (<pivot> +- <tolerance>)
”
syntax of Matchers
.”“
Returns a TripleEqualsInvocationOnInterval[T]
, given an Interval[T]
, to facilitate
the “<left> should === (<pivot> +- <tolerance>)
”
syntax of Matchers
.
the Interval[T]
against which to compare the left-hand value
a TripleEqualsInvocationOnInterval
wrapping the passed Interval[T]
value, with
expectingEqual
set to true
.
Returns a TripleEqualsInvocation[Null]
, given a null
reference, to facilitate
the “<left> should === null
” syntax
of Matchers
.”“
Returns a TripleEqualsInvocation[Null]
, given a null
reference, to facilitate
the “<left> should === null
” syntax
of Matchers
.
a null reference
a TripleEqualsInvocation
wrapping the passed null
value, with expectingEqual
set to true
.
Returns a TripleEqualsInvocation[T]
, given an object of type T
, to facilitate
the “<left> should === <right>
” syntax
of Matchers
.”“
Returns a TripleEqualsInvocation[T]
, given an object of type T
, to facilitate
the “<left> should === <right>
” syntax
of Matchers
.
the right-hand side value for an equality assertion
a TripleEqualsInvocation
wrapping the passed right value, with expectingEqual
set to true
.
Provides an EqualityConstraint[A, B]
class for any two types A
and B
, enforcing the type constraint that B
is implicitly convertible to A
, given an implicit Equality[A]
.
Provides an EqualityConstraint[A, B]
class for any two types A
and B
, enforcing the type constraint that B
is implicitly convertible to A
, given an implicit Equality[A]
.
The implicitly passed Equality[A]
must be used to determine equality by the returned EqualityConstraint
's
areEqual
method.
This method is overridden and made implicit by subtraits
ConversionCheckedTripleEquals
) and
ConversionCheckedLegacyTripleEquals
, and
overriden as non-implicit by the other subtraits in this package.
an Equality[A]
type class to which the EqualityConstraint.areEqual
method will delegate to determine equality.
an implicit conversion from B
to A
an EqualityConstraint[A, B]
whose areEqual
method delegates to the areEqual
method of
the passed Equality[A]
.
Convert to an CheckingEqualizer
that provides ===
and !==
operators that result in Boolean
and enforce a type constraint.
Convert to an CheckingEqualizer
that provides ===
and !==
operators that result in Boolean
and enforce a type constraint.
This method is overridden and made implicit by subtraits TypeCheckedTripleEquals
and ConversionCheckedTripleEquals
, and overriden as
non-implicit by the other subtraits in this package.
the object whose type to convert to CheckingEqualizer
.
Convert to an Equalizer
that provides ===
and !==
operators that
result in Boolean
and enforce no type constraint.
Convert to an Equalizer
that provides ===
and !==
operators that
result in Boolean
and enforce no type constraint.
This method is overridden and made implicit by subtrait TripleEquals
and overriden as non-implicit by the other subtraits in this package.
the object whose type to convert to Equalizer
.
Convert to a LegacyCheckingEqualizer
that provides ===
and !==
operators that result in Option[String]
and
enforce a type constraint.
Convert to a LegacyCheckingEqualizer
that provides ===
and !==
operators that result in Option[String]
and
enforce a type constraint.
This method is overridden and made implicit by subtraits TypeCheckedLegacyTripleEquals
and ConversionCheckedLegacyTripleEquals
, and
overriden as non-implicit by the other subtraits in this package.
the object whose type to convert to LegacyCheckingEqualizer
.
Convert to a LegacyEqualizer
that provides ===
and !==
operators that
result in Option[String]
and enforce no type constraint.
Convert to a LegacyEqualizer
that provides ===
and !==
operators that
result in Option[String]
and enforce no type constraint.
This method is overridden and made implicit by subtrait LegacyTripleEquals
and overriden as non-implicit by the other subtraits in this package.
the object whose type to convert to LegacyEqualizer
.
Return an Equality[A]
for any type A
that determines equality via the ==
operator on type A
.
Return an Equality[A]
for any type A
that determines equality via the ==
operator on type A
.
a DefaultEquality
for type A
Provides an EqualityConstraint[A, B]
class for any two types A
and B
, enforcing the type constraint that A
is implicitly convertible to B
, given an implicit Equality[A]
.
Provides an EqualityConstraint[A, B]
class for any two types A
and B
, enforcing the type constraint that A
is implicitly convertible to B
, given an implicit Equality[A]
.
The implicitly passed Equality[A]
must be used to determine equality by the returned EqualityConstraint
's
areEqual
method.
This method is overridden and made implicit by subtraits
LowPriorityConversionCheckedConstraint
(extended by
ConversionCheckedTripleEquals
), and
LowPriorityConversionCheckedLegacyConstraint
(extended by
ConversionCheckedLegacyTripleEquals
), and
overriden as non-implicit by the other subtraits in this package.
an implicit conversion from A
to B
an EqualityConstraint[A, B]
whose areEqual
method delegates to the areEqual
method of
the passed Equality[A]
.
Provides an EqualityConstraint[A, B]
class for any two types A
and B
, enforcing the type constraint that A
must be a subtype of B
, given an implicit Equality[A]
.
Provides an EqualityConstraint[A, B]
class for any two types A
and B
, enforcing the type constraint that A
must be a subtype of B
, given an implicit Equality[A]
.
The implicitly passed Equality[A]
must be used to determine equality by the returned EqualityConstraint
's
areEqual
method.
This method is overridden and made implicit by subtraits
LowPriorityTypeCheckedConstraint
(extended by
TypeCheckedTripleEquals
), and
LowPriorityTypeCheckedLegacyConstraint
(extended by
TypeCheckedLegacyTripleEquals
), and
overriden as non-implicit by the other subtraits in this package.
an Equality[A]
type class to which the EqualityConstraint.areEqual
method
will delegate to determine equality.
evidence that A
is a subype of B
an EqualityConstraint[A, B]
whose areEqual
method delegates to the
areEqual
method of the passed Equality[A]
.
Provides an EqualityConstraint[A, B]
class for any two types A
and B
, enforcing the type constraint that B
must be a subtype of A
, given an implicit Equality[A]
.
Provides an EqualityConstraint[A, B]
class for any two types A
and B
, enforcing the type constraint that B
must be a subtype of A
, given an implicit Equality[A]
.
The implicitly passed Equality[A]
must be used to determine equality by the returned EqualityConstraint
's
areEqual
method.
This method is overridden and made implicit by subtraits
TypeCheckedTripleEquals
) and
TypeCheckedLegacyTripleEquals
, and
overriden as non-implicit by the other subtraits in this package.
an Equality[A]
type class to which the EqualityConstraint.areEqual
method will delegate to determine equality.
evidence that B
is a subype of A
an EqualityConstraint[A, B]
whose areEqual
method delegates to the areEqual
method of
the passed Equality[A]
.
Provides an EqualityConstraint[A, B]
class for any two types A
and B
, with no type constraint enforced, given an
implicit Equality[A]
.
Provides an EqualityConstraint[A, B]
class for any two types A
and B
, with no type constraint enforced, given an
implicit Equality[A]
.
The implicitly passed Equality[A]
must be used to determine equality by the returned EqualityConstraint
's
areEqual
method.
This method is overridden and made implicit by subtraits TripleEquals
and LegacyTripleEquals
, and
overriden as non-implicit by the other subtraits in this package.
an Equality[A]
type class to which the EqualityConstraint.areEqual
method will delegate to determine equality.
an EqualityConstraint[A, B]
whose areEqual
method delegates to the areEqual
method of
the passed Equality[A]
.
Provides
===
and!==
operators that returnBoolean
, delegate the equality determination to anEquality
type class, and require no relationship between the types of the two values compared.LegacyTripleEquals
is useful (in test, not production, code) when you need determine equality for a type of object differently than itsequals
method: either you can't change theequals
method, or theequals
method is sensible generally, but you are in a special situation where you need something else. If you also want a compile-time type check, however, you should use one ofLegacyTripleEquals
sibling traits:ConversionCheckedLegacyTripleEquals
orTypeCheckedLegacyTripleEquals
.Note: This trait is extended by
org.scalatest.Assertions
, because it provides the same kind of===
operator that was historically provided byAssertions
. The purpose of this trait is to maintain compatibility with existing ScalaTest code that uses the original===
operator. After ScalaTest no longer supports Scala 2.9, the “legacy” triple equals traits will be deprecated and eventually removed. Good error messages will be obtained for both==
and===
through assert macros. In the transition phase, you can in production code use regular triple equals traits, whose===
operators returnBoolean
, and in test code use "legacy" triple equals traits, whose===
operators returnOption[String]
.This trait will override or hide implicit methods defined by its sibling traits,
ConversionCheckedLegacyTripleEquals
orTypeCheckedLegacyTripleEquals
, and can therefore be used to temporarily turn of type checking in a limited scope. Because the methods inLegacyTripleEquals
(and its siblings)override all the methods defined in supertypeEqualityConstraints
, you can achieve the same kind of nested tuning of equality constraints whether you mix in traits, import from companion objects, or use some combination of both.In short, you should be able to select a primary constraint level via either a mixin or import, then change that in nested scopes however you want, again either through a mixin or import, without getting any implicit conversion ambiguity. The innermost constraint level in scope will always be in force.