* 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
 |