* Fix coding standards; * Simplify some expectations (eq instead of be matcher); * Expect identity on block instead of calling; * Change some before call as oneliners; * Avoid shadowing variable names; * Improve wording where needed.
		
			
				
	
	
		
			36 lines
		
	
	
		
			934 B
		
	
	
	
		
			Ruby
		
	
	
	
	
	
			
		
		
	
	
			36 lines
		
	
	
		
			934 B
		
	
	
	
		
			Ruby
		
	
	
	
	
	
require 'spec_helper'
 | 
						|
 | 
						|
module Producer::Core
 | 
						|
  describe Interpreter do
 | 
						|
    subject(:interpreter) { Interpreter.new }
 | 
						|
 | 
						|
    describe '#process' do
 | 
						|
      it 'processes each task' do
 | 
						|
        expect(interpreter).to receive(:process_task).with(:some_task)
 | 
						|
        interpreter.process [:some_task]
 | 
						|
      end
 | 
						|
    end
 | 
						|
 | 
						|
    describe '#process_task' do
 | 
						|
      let(:action)  { double 'action' }
 | 
						|
      let(:task)    { double('task', actions: [action]).as_null_object }
 | 
						|
 | 
						|
      context 'when task condition is met' do
 | 
						|
        it 'applies the actions' do
 | 
						|
          expect(action).to receive :apply
 | 
						|
          interpreter.process_task task
 | 
						|
        end
 | 
						|
      end
 | 
						|
 | 
						|
      context 'when task condition is not met' do
 | 
						|
        before { allow(task).to receive(:condition_met?) { false } }
 | 
						|
 | 
						|
        it 'does not apply the actions' do
 | 
						|
          expect(action).not_to receive :apply
 | 
						|
          interpreter.process_task task
 | 
						|
        end
 | 
						|
      end
 | 
						|
    end
 | 
						|
  end
 | 
						|
end
 |