2014-05-25 12:12:09 +00:00

89 lines
2.3 KiB
Ruby

require 'spec_helper'
module Producer::Core
describe Task do
let(:name) { :some_task }
let(:action) { double 'action' }
let(:condition) { double 'condition' }
subject(:task) { Task.new(name, [action], condition) }
describe '.evaluate' do
let(:name) { :some_task }
let(:env) { double 'env' }
let(:block) { proc { condition { :condition }; some_action } }
let(:some_action_class) { Class.new(Action) }
subject(:task) { Task.evaluate(name, env, :some, :args, &block) }
before { Task::DSL.define_action(:some_action, some_action_class) }
it 'returns an evaluated task' do
expect(task).to be_kind_of Task
end
context 'evaluated task' do
it 'has the requested name' do
expect(task.name).to eq name
end
it 'has the requested actions' do
expect(task.actions.first).to be_kind_of some_action_class
end
it 'has the requested condition' do
expect(task.condition.return_value).to be :condition
end
end
end
describe '#initialize' do
it 'assigns the name' do
expect(task.name).to eq name
end
it 'assigns the actions' do
expect(task.actions).to eq [action]
end
it 'assigns the condition' do
expect(task.condition).to eq condition
end
context 'when only the name is given as argument' do
subject(:task) { described_class.new(name) }
it 'assigns no action' do
expect(task.actions).to be_empty
end
it 'assigns a true condition' do
expect(task.condition).to be true
end
end
end
describe '#to_s' do
it 'includes the task name' do
expect(task.to_s).to include name.to_s
end
end
describe '#condition_met?' do
context 'when condition is truthy' do
let(:condition) { Condition.new([], true) }
it 'returns true' do
expect(task.condition_met?).to be true
end
end
context 'when condition is falsy' do
let(:condition) { Condition.new([], false) }
it 'returns false' do
expect(task.condition_met?).to be false
end
end
end
end
end