diff options
Diffstat (limited to 'spec/hashie/extensions/mash/define_accessors_spec.rb')
-rw-r--r-- | spec/hashie/extensions/mash/define_accessors_spec.rb | 90 |
1 files changed, 90 insertions, 0 deletions
diff --git a/spec/hashie/extensions/mash/define_accessors_spec.rb b/spec/hashie/extensions/mash/define_accessors_spec.rb new file mode 100644 index 0000000..de7abe7 --- /dev/null +++ b/spec/hashie/extensions/mash/define_accessors_spec.rb @@ -0,0 +1,90 @@ +require 'spec_helper' + +describe Hashie::Extensions::Mash::DefineAccessors do + let(:args) { [] } + + shared_examples 'class with dynamically defined accessors' do + it 'defines reader on demand' do + expect(subject.method_defined?(:foo)).to be_falsey + instance.foo + expect(subject.method_defined?(:foo)).to be_truthy + end + + it 'defines writer on demand' do + expect(subject.method_defined?(:foo=)).to be_falsey + instance.foo = :bar + expect(subject.method_defined?(:foo=)).to be_truthy + end + + it 'defines predicate on demand' do + expect(subject.method_defined?(:foo?)).to be_falsey + instance.foo? + expect(subject.method_defined?(:foo?)).to be_truthy + end + + it 'defines initializing reader on demand' do + expect(subject.method_defined?(:foo!)).to be_falsey + instance.foo! + expect(subject.method_defined?(:foo!)).to be_truthy + end + + it 'defines underbang reader on demand' do + expect(subject.method_defined?(:foo_)).to be_falsey + instance.foo_ + expect(subject.method_defined?(:foo_)).to be_truthy + end + + context 'when initializing from another hash' do + let(:args) { [{ foo: :bar }] } + + it 'does not define any accessors' do + expect(subject.method_defined?(:foo)).to be_falsey + expect(subject.method_defined?(:foo=)).to be_falsey + expect(subject.method_defined?(:foo?)).to be_falsey + expect(subject.method_defined?(:foo!)).to be_falsey + expect(subject.method_defined?(:foo_)).to be_falsey + expect(instance.foo).to eq :bar + end + end + end + + context 'when included in Mash subclass' do + subject { Class.new(Hashie::Mash) { include Hashie::Extensions::Mash::DefineAccessors } } + let(:instance) { subject.new(*args) } + + describe 'this subclass' do + it_behaves_like 'class with dynamically defined accessors' + + describe 'when accessors are overrided in class' do + before do + subject.class_eval do + def foo + if self[:foo] != 1 + :bar + else + super + end + end + end + end + + it 'allows to call super' do + expect(instance.foo).to eq :bar + instance.foo = 2 + expect(instance.foo).to eq :bar + instance.foo = 1 + expect(instance.foo).to eq 1 + end + end + end + end + + context 'when Mash instance is extended' do + let(:instance) { Hashie::Mash.new(*args).with_accessors! } + subject { instance.singleton_class } + + describe 'its singleton class' do + it_behaves_like 'class with dynamically defined accessors' + end + end +end |