require File.join(File.dirname(File.dirname(File.dirname(File.expand_path(__FILE__)))), 'spec_helper') require File.join(File.dirname(File.dirname(File.dirname(File.dirname(File.expand_path(__FILE__))))), 'lib', 'reek', 'smells', 'nested_iterators') require File.join(File.dirname(File.expand_path(__FILE__)), 'smell_detector_shared') include Reek::Smells describe NestedIterators do context 'with no iterators' do it 'reports no smells' do src = 'def fred() nothing = true; end' src.should_not smell_of(NestedIterators) end end context 'with one iterator' do it 'reports no smells' do src = 'def fred() nothing.each {|item| item}; end' src.should_not smell_of(NestedIterators) end end it 'should report nested iterators in a method' do src = 'def bad(fred) @fred.each {|item| item.each {|ting| ting.ting} } end' src.should smell_of(NestedIterators) end it 'should not report method with successive iterators' do src = < 3} end it 'should not report nested iterators 2 levels deep' do src = < ['ignore_me']} end it 'should not report nesting the ignored iterator inside another' do src = 'def bad(fred) @fred.each {|item| item.ignore_me {|ting| ting.ting} } end' src.should_not smell_of(NestedIterators).with_config(@config) end it 'should not report nesting inside the ignored iterator' do src = 'def bad(fred) @fred.ignore_me {|item| item.each {|ting| ting.ting} } end' src.should_not smell_of(NestedIterators).with_config(@config) end it 'should report nested iterators inside the ignored iterator' do src = 'def bad(fred) @fred.ignore_me {|item| item.each {|ting| ting.each {|other| other.other} } } end' src.should smell_of(NestedIterators, NestedIterators::NESTING_DEPTH_KEY => 2).with_config(@config) end it 'should report nested iterators outside the ignored iterator' do src = 'def bad(fred) @fred.each {|item| item.each {|ting| ting.ignore_me {|other| other.other} } } end' src.should smell_of(NestedIterators, NestedIterators::NESTING_DEPTH_KEY => 2).with_config(@config) end it 'should report nested iterators with the ignored iterator between them' do src = 'def bad(fred) @fred.each {|item| item.ignore_me {|ting| ting.ting {|other| other.other} } } end' src.should smell_of(NestedIterators, NestedIterators::NESTING_DEPTH_KEY => 2).with_config(@config) end end end describe NestedIterators do before(:each) do @source_name = 'cuckoo' @detector = NestedIterators.new(@source_name) end it_should_behave_like 'SmellDetector' context 'when a smell is reported' do before :each do src = <