mirror of
https://gitea.invidious.io/iv-org/shard-spectator.git
synced 2024-08-15 00:53:35 +00:00
66 lines
2.3 KiB
Crystal
66 lines
2.3 KiB
Crystal
require "./value_matcher"
|
|
|
|
module Spectator::Matchers
|
|
# Matcher that tests whether a set has a specified number of elements.
|
|
# The set's `#size` method is used for this check.
|
|
struct SizeMatcher(ExpectedType) < ValueMatcher(ExpectedType)
|
|
# Short text about the matcher's purpose.
|
|
# This explains what condition satisfies the matcher.
|
|
# The description is used when the one-liner syntax is used.
|
|
def description : String
|
|
"has size #{expected.label}"
|
|
end
|
|
|
|
# Checks whether the matcher is satisfied with the expression given to it.
|
|
private def match?(actual : Expression(T)) : Bool forall T
|
|
actual_value = actual.value
|
|
return unexpected(actual_value, actual.label) unless actual_value.responds_to?(:size?)
|
|
|
|
expected.value == actual_value.size
|
|
end
|
|
|
|
# Message displayed when the matcher isn't satisfied.
|
|
#
|
|
# This is only called when `#match?` returns false.
|
|
#
|
|
# The message should typically only contain the test expression labels.
|
|
# Actual values should be returned by `#values`.
|
|
private def failure_message(actual) : String
|
|
"#{actual.label} does not have #{expected.label} elements"
|
|
end
|
|
|
|
# Message displayed when the matcher isn't satisfied and is negated.
|
|
# This is essentially what would satisfy the matcher if it wasn't negated.
|
|
#
|
|
# This is only called when `#does_not_match?` returns false.
|
|
#
|
|
# The message should typically only contain the test expression labels.
|
|
# Actual values should be returned by `#values`.
|
|
private def failure_message_when_negated(actual) : String
|
|
"#{actual.label} has #{expected.label} elements"
|
|
end
|
|
|
|
# Additional information about the match failure.
|
|
# The return value is a NamedTuple with Strings for each value.
|
|
private def values(actual)
|
|
{
|
|
expected: expected.value.inspect,
|
|
actual: actual.value.size.inspect,
|
|
}
|
|
end
|
|
|
|
# Additional information about the match failure when negated.
|
|
# The return value is a NamedTuple with Strings for each value.
|
|
private def negated_values(actual)
|
|
{
|
|
expected: "Not #{expected.value.inspect}",
|
|
actual: actual.value.size.inspect,
|
|
}
|
|
end
|
|
|
|
private def unexpected(value, label)
|
|
raise "#{label} must respond to `#size`. #{label}: #{value.inspect}"
|
|
end
|
|
end
|
|
end
|