spec/rake/funnel/integration/progress_report_spec.rb in rake-funnel-0.3.2.pre vs spec/rake/funnel/integration/progress_report_spec.rb in rake-funnel-0.4.0.pre
- old
+ new
@@ -1,149 +1,149 @@
-include Rake
-include Rake::Funnel::Integration
-
-describe Rake::Funnel::Integration::ProgressReport do
- include DSL
-
- let(:teamcity_running?) { false }
-
- before {
- allow($stdout).to receive(:puts)
- allow(TeamCity).to receive(:running?).and_return(teamcity_running?)
-
- Task.clear
- }
-
- after {
- subject.disable!
- }
-
- describe 'defaults' do
- subject! {
- described_class.new
- }
-
- before {
- task :task
-
- Task[:task].invoke
- }
-
- context 'not on TeamCity' do
- it 'should write task name in square brackets' do
- expect($stdout).to have_received(:puts).with("\n[task]")
- end
- end
-
- context 'on TeamCity' do
- let(:teamcity_running?) { true }
-
- it 'should not write task name in square brackets since it would clutter the output' do
- expect($stdout).to_not have_received(:puts).with("\n[task]")
- end
- end
- end
-
- context 'when progess report was disabled' do
- subject! {
- described_class.new
- }
-
- before {
- subject.disable!
-
- task :task
-
- Task[:task].invoke
- }
-
- it 'should not write' do
- expect($stdout).to_not have_received(:puts).with("\n[task]")
- end
- end
-
- describe 'custom event handlers' do
- let(:receiver) { double.as_null_object }
-
- subject! {
- described_class.new do |r|
- r.task_starting do |task, args|
- receiver.starting({
- task: task,
- args: args
- })
- end
-
- r.task_finished do |task, args, error|
- receiver.finished({
- task: task,
- args: args,
- error: error
- })
- end
- end
- }
-
- context 'when task succeeds' do
- before {
- task :task
-
- Task[:task].invoke
- }
-
- describe 'starting handler' do
- it 'should run' do
- expect(receiver).to have_received(:starting)
- end
-
- it 'should receive task' do
- expect(receiver).to have_received(:starting).with(hash_including({ task: kind_of(Task) }))
- end
-
- it 'should receive task arguments' do
- expect(receiver).to have_received(:starting).with(hash_including({ args: kind_of(TaskArguments) }))
- end
- end
-
- describe 'finished handler' do
- it 'should run' do
- expect(receiver).to have_received(:finished)
- end
-
- it 'should receive task' do
- expect(receiver).to have_received(:finished).with(hash_including({ task: kind_of(Task) }))
- end
-
- it 'should receive task arguments' do
- expect(receiver).to have_received(:finished).with(hash_including({ args: kind_of(TaskArguments) }))
- end
-
- it 'should not receive error' do
- expect(receiver).to have_received(:finished).with(hash_including({ error: nil }))
- end
- end
- end
-
- context 'when task fails' do
- class SpecificError < StandardError; end
-
- let(:error) { SpecificError.new('task error') }
-
- before {
- task :task do
- raise error
- end
-
- begin
- Task[:task].invoke
- rescue SpecificError
- end
- }
-
- describe 'finished handler' do
- it 'should receive error' do
- expect(receiver).to have_received(:finished).with(hash_including({ error: error }))
- end
- end
- end
- end
-end
+include Rake
+include Rake::Funnel::Integration
+
+describe Rake::Funnel::Integration::ProgressReport do
+ include DSL
+
+ let(:teamcity_running?) { false }
+
+ before {
+ allow($stdout).to receive(:puts)
+ allow(TeamCity).to receive(:running?).and_return(teamcity_running?)
+
+ Task.clear
+ }
+
+ after {
+ subject.disable!
+ }
+
+ describe 'defaults' do
+ subject! {
+ described_class.new
+ }
+
+ before {
+ task :task
+
+ Task[:task].invoke
+ }
+
+ context 'not on TeamCity' do
+ it 'should write task name in square brackets' do
+ expect($stdout).to have_received(:puts).with("\n[task]")
+ end
+ end
+
+ context 'on TeamCity' do
+ let(:teamcity_running?) { true }
+
+ it 'should not write task name in square brackets since it would clutter the output' do
+ expect($stdout).to_not have_received(:puts).with("\n[task]")
+ end
+ end
+ end
+
+ context 'when progess report was disabled' do
+ subject {
+ described_class.new
+ }
+
+ before {
+ subject.disable!
+
+ task :task
+
+ Task[:task].invoke
+ }
+
+ it 'should not write' do
+ expect($stdout).to_not have_received(:puts).with("\n[task]")
+ end
+ end
+
+ describe 'custom event handlers' do
+ let(:receiver) { double.as_null_object }
+
+ subject! {
+ described_class.new do |r|
+ r.task_starting do |task, args|
+ receiver.task_starting({
+ task: task,
+ args: args
+ })
+ end
+
+ r.task_finished do |task, args, error|
+ receiver.task_finished({
+ task: task,
+ args: args,
+ error: error
+ })
+ end
+ end
+ }
+
+ context 'when task succeeds' do
+ before {
+ task :task
+
+ Task[:task].invoke
+ }
+
+ describe 'starting handler' do
+ it 'should run' do
+ expect(receiver).to have_received(:task_starting)
+ end
+
+ it 'should receive task' do
+ expect(receiver).to have_received(:task_starting).with(hash_including({ task: kind_of(Task) }))
+ end
+
+ it 'should receive task arguments' do
+ expect(receiver).to have_received(:task_starting).with(hash_including({ args: kind_of(TaskArguments) }))
+ end
+ end
+
+ describe 'finished handler' do
+ it 'should run' do
+ expect(receiver).to have_received(:task_finished)
+ end
+
+ it 'should receive task' do
+ expect(receiver).to have_received(:task_finished).with(hash_including({ task: kind_of(Task) }))
+ end
+
+ it 'should receive task arguments' do
+ expect(receiver).to have_received(:task_finished).with(hash_including({ args: kind_of(TaskArguments) }))
+ end
+
+ it 'should not receive error' do
+ expect(receiver).to have_received(:task_finished).with(hash_including({ error: nil }))
+ end
+ end
+ end
+
+ context 'when task fails' do
+ class SpecificError < StandardError; end
+
+ let(:error) { SpecificError.new('task error') }
+
+ before {
+ task :task do
+ raise error
+ end
+
+ begin
+ Task[:task].invoke
+ rescue SpecificError
+ end
+ }
+
+ describe 'finished handler' do
+ it 'should receive error' do
+ expect(receiver).to have_received(:task_finished).with(hash_including({ error: error }))
+ end
+ end
+ end
+ end
+end