diff --git a/lib/cucumber/core/test/mapper.rb b/lib/cucumber/core/test/mapper.rb index aa197003..8925a346 100644 --- a/lib/cucumber/core/test/mapper.rb +++ b/lib/cucumber/core/test/mapper.rb @@ -65,7 +65,7 @@ def before(&block) # Run this block of code after the scenario def after(&block) - mapper.after_hooks << hook_factory.after(block) + mapper.after_hooks.unshift(hook_factory.after(block)) self end diff --git a/spec/cucumber/core/test/mapper_spec.rb b/spec/cucumber/core/test/mapper_spec.rb index 2728f072..f3f7fd43 100644 --- a/spec/cucumber/core/test/mapper_spec.rb +++ b/spec/cucumber/core/test/mapper_spec.rb @@ -97,15 +97,19 @@ def test_step(test_step, mapper) it "adds hooks in the right order" do log = double allow(mappings).to receive(:test_case) do |test_case, mapper| - mapper.before { log.before } - mapper.after { log.after } + mapper.before { log.before_hook_1 } + mapper.before { log.before_hook_2 } + mapper.after { log.after_hook_1 } + mapper.after { log.after_hook_2 } end - mapped_step = test_step.with_mapping { log.step } + mapped_step = test_step.with_mapping { log.step_1 } test_case = Case.new([mapped_step], source) - expect( log ).to receive(:before).ordered - expect( log ).to receive(:step).ordered - expect( log ).to receive(:after).ordered + expect( log ).to receive(:before_hook_1).ordered + expect( log ).to receive(:before_hook_2).ordered + expect( log ).to receive(:step_1).ordered + expect( log ).to receive(:after_hook_2).ordered + expect( log ).to receive(:after_hook_1).ordered allow(receiver).to receive(:test_case).and_yield(receiver) allow(receiver).to receive(:test_step) do |test_step| @@ -128,7 +132,7 @@ def test_step(test_step, mapper) expect( scenario ).to receive(:describe_to) expect( visitor ).to receive(:before_hook) do |hook, hook_args| expect( args ).to eq(hook_args) - expect( hook.location.to_s ).to eq("#{__FILE__}:121") + expect( hook.location.to_s ).to eq("#{__FILE__}:125") end test_step.describe_source_to(visitor, args) end @@ -148,7 +152,7 @@ def test_step(test_step, mapper) expect( scenario ).to receive(:describe_to) expect( visitor ).to receive(:after_hook) do |hook, hook_args| expect( args ).to eq(hook_args) - expect( hook.location.to_s ).to eq("#{__FILE__}:141") + expect( hook.location.to_s ).to eq("#{__FILE__}:145") end test_step.describe_source_to(visitor, args) end @@ -168,7 +172,7 @@ def test_step(test_step, mapper) expect( visitor ).to receive(:step).ordered expect( visitor ).to receive(:after_step_hook) do |hook, hook_args| expect( args ).to eq(hook_args) - expect( hook.location.to_s ).to eq("#{__FILE__}:160") + expect( hook.location.to_s ).to eq("#{__FILE__}:164") end.once.ordered expect( visitor ).to receive(:step).ordered test_case.describe_to mapper @@ -180,4 +184,3 @@ def test_step(test_step, mapper) end end end -