spec/lib/sinclair/method_definition_spec.rb in sinclair-1.9.0 vs spec/lib/sinclair/method_definition_spec.rb in sinclair-1.10.0

- old
+ new

@@ -40,6 +40,70 @@ expect(described_class.from(method_name, 'code')) .to be_a(described_class::StringDefinition) end end end + + describe '.for' do + context 'when there are no options nor block' do + let(:type) { :call } + let(:arguments) { %i[attr_reader some_attribute other_attribute] } + + it do + expect(described_class.for(type, *arguments)) + .to be_a(described_class) + end + + it 'Returns an instance of the given type' do + expect(described_class.for(type, *arguments)) + .to be_a(described_class::CallDefinition) + end + + it 'initializes it correctly' do + expect(described_class.for(type, *arguments).code_string) + .to eq('attr_reader :some_attribute, :other_attribute') + end + end + + context 'when a block is given' do + let(:type) { :block } + let(:method_name) { :the_method } + let(:block) { proc { 10 } } + + it do + expect(described_class.for(type, method_name, &block)) + .to be_a(described_class) + end + + it 'Returns an instance of the given type' do + expect(described_class.for(type, method_name, &block)) + .to be_a(described_class::BlockDefinition) + end + + it 'initializes it correctly' do + expect(described_class.for(type, method_name, &block).name) + .to eq(method_name) + end + end + + context 'when options are given' do + let(:type) { :string } + let(:method_name) { :the_method } + let(:code) { '10' } + + it do + expect(described_class.for(type, method_name, code)) + .to be_a(described_class) + end + + it 'Returns an instance of the given type' do + expect(described_class.for(type, method_name, code)) + .to be_a(described_class::StringDefinition) + end + + it 'initializes it correctly' do + expect(described_class.for(type, method_name, code).name) + .to eq(method_name) + end + end + end end