Support variables and methods for type matcher (be_a).
Addresses https://github.com/icy-arctic-fox/spectator/issues/25
This commit is contained in:
parent
2ec6a31f34
commit
93e270f87a
|
@ -0,0 +1,26 @@
|
|||
require "../spec_helper"
|
||||
|
||||
Spectator.describe Spectator::Matchers::TypeMatcher do
|
||||
context String do # Sets `described_class` to String
|
||||
def other_type
|
||||
Int32
|
||||
end
|
||||
|
||||
describe "#|" do
|
||||
it "works on sets" do
|
||||
super_set = (described_class | other_type)
|
||||
|
||||
expect(42).to be_kind_of(super_set)
|
||||
expect("foo").to be_a(super_set)
|
||||
end
|
||||
end
|
||||
|
||||
it "works on described_class" do
|
||||
expect("foo").to be_a_kind_of(described_class)
|
||||
end
|
||||
|
||||
it "works on plain types" do
|
||||
expect(42).to be_a(Int32)
|
||||
end
|
||||
end
|
||||
end
|
|
@ -77,7 +77,7 @@ module Spectator
|
|||
# expect(x).to be_a(Int32 | String)
|
||||
# ```
|
||||
macro be_a(expected)
|
||||
::Spectator::Matchers::TypeMatcher({{expected}}).new
|
||||
::Spectator::Matchers::TypeMatcher.create({{expected}})
|
||||
end
|
||||
|
||||
# Indicates that some value should be of a specified type.
|
||||
|
|
|
@ -4,6 +4,11 @@ module Spectator::Matchers
|
|||
# Matcher that tests a value is of a specified type.
|
||||
# The values are compared with the `Object#is_a?` method.
|
||||
struct TypeMatcher(Expected) < StandardMatcher
|
||||
# Alternate constructor that works with constant types and types from variables.
|
||||
def self.create(type : T.class) forall T
|
||||
TypeMatcher(T).new
|
||||
end
|
||||
|
||||
# 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.
|
||||
|
|
Loading…
Reference in New Issue