Support variables and methods for type matcher (be_a).

Addresses https://github.com/icy-arctic-fox/spectator/issues/25
This commit is contained in:
Michael Miller 2021-04-17 09:38:29 -06:00
parent 2ec6a31f34
commit 93e270f87a
No known key found for this signature in database
GPG Key ID: FB9F12F7C646A4AD
3 changed files with 32 additions and 1 deletions

View File

@ -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

View File

@ -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.

View File

@ -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.