Modify recipe DSL API to take env on initialization
This commit is contained in:
parent
1d6ae126ed
commit
352fcd37f8
@ -3,7 +3,7 @@ module Producer
|
|||||||
class Recipe
|
class Recipe
|
||||||
class << self
|
class << self
|
||||||
def evaluate_from_file(filepath, env)
|
def evaluate_from_file(filepath, env)
|
||||||
dsl = DSL.new(File.read(filepath)).evaluate(env)
|
dsl = DSL.new(env, File.read(filepath)).evaluate
|
||||||
Recipe.new(dsl.tasks)
|
Recipe.new(dsl.tasks)
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
@ -2,16 +2,16 @@ module Producer
|
|||||||
module Core
|
module Core
|
||||||
class Recipe
|
class Recipe
|
||||||
class DSL
|
class DSL
|
||||||
attr_reader :tasks
|
attr_reader :env, :tasks
|
||||||
|
|
||||||
def initialize(code = nil, &block)
|
def initialize(env, code = nil, &block)
|
||||||
|
@env = env
|
||||||
@code = code
|
@code = code
|
||||||
@block = block
|
@block = block
|
||||||
@tasks = []
|
@tasks = []
|
||||||
end
|
end
|
||||||
|
|
||||||
def evaluate(env)
|
def evaluate
|
||||||
@env = env
|
|
||||||
if @code
|
if @code
|
||||||
instance_eval @code
|
instance_eval @code
|
||||||
else
|
else
|
||||||
@ -22,10 +22,6 @@ module Producer
|
|||||||
|
|
||||||
private
|
private
|
||||||
|
|
||||||
def env
|
|
||||||
@env
|
|
||||||
end
|
|
||||||
|
|
||||||
def source(filepath)
|
def source(filepath)
|
||||||
instance_eval File.read("./#{filepath}.rb"), "#{filepath}.rb"
|
instance_eval File.read("./#{filepath}.rb"), "#{filepath}.rb"
|
||||||
end
|
end
|
||||||
|
@ -6,16 +6,20 @@ module Producer::Core
|
|||||||
|
|
||||||
let(:code) { proc { :some_recipe_code } }
|
let(:code) { proc { :some_recipe_code } }
|
||||||
let(:env) { double('env').as_null_object }
|
let(:env) { double('env').as_null_object }
|
||||||
subject(:dsl) { Recipe::DSL.new(&code) }
|
subject(:dsl) { Recipe::DSL.new(env, &code) }
|
||||||
|
|
||||||
describe '#initialize' do
|
describe '#initialize' do
|
||||||
|
it 'assigns the given env' do
|
||||||
|
expect(dsl.env).to be env
|
||||||
|
end
|
||||||
|
|
||||||
it 'assigns no task' do
|
it 'assigns no task' do
|
||||||
expect(dsl.instance_eval { @tasks }).to be_empty
|
expect(dsl.instance_eval { @tasks }).to be_empty
|
||||||
end
|
end
|
||||||
|
|
||||||
context 'when a string of code is given as argument' do
|
context 'when a string of code is given as argument' do
|
||||||
let(:code) { 'some_code' }
|
let(:code) { 'some_code' }
|
||||||
subject(:dsl) { Recipe::DSL.new(code) }
|
subject(:dsl) { Recipe::DSL.new(env, code) }
|
||||||
|
|
||||||
it 'assigns the string of code' do
|
it 'assigns the string of code' do
|
||||||
expect(dsl.instance_eval { @code }).to eq code
|
expect(dsl.instance_eval { @code }).to eq code
|
||||||
@ -33,41 +37,41 @@ module Producer::Core
|
|||||||
let(:code) { proc { task(:some_task) { } } }
|
let(:code) { proc { task(:some_task) { } } }
|
||||||
|
|
||||||
it 'returns registered tasks' do
|
it 'returns registered tasks' do
|
||||||
dsl.evaluate env
|
dsl.evaluate
|
||||||
expect(dsl.tasks[0].name).to eq :some_task
|
expect(dsl.tasks[0].name).to eq :some_task
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
describe '#evaluate' do
|
describe '#evaluate' do
|
||||||
it 'evaluates its code' do
|
it 'evaluates its code' do
|
||||||
dsl = Recipe::DSL.new { throw :recipe_code }
|
dsl = Recipe::DSL.new(env) { throw :recipe_code }
|
||||||
expect { dsl.evaluate env }.to throw_symbol :recipe_code
|
expect { dsl.evaluate }.to throw_symbol :recipe_code
|
||||||
end
|
end
|
||||||
|
|
||||||
it 'returns itself' do
|
it 'returns itself' do
|
||||||
expect(dsl.evaluate env).to eq dsl
|
expect(dsl.evaluate).to eq dsl
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
context 'DSL specific methods' do
|
context 'DSL specific methods' do
|
||||||
subject(:dsl) { Recipe::DSL.new(&code).evaluate(env) }
|
subject(:dsl) { Recipe::DSL.new(env, &code).evaluate }
|
||||||
|
|
||||||
describe '#env' do
|
describe '#env' do
|
||||||
let(:code) { proc { env.some_message } }
|
let(:code) { proc { env.some_message } }
|
||||||
|
|
||||||
it 'returns the current environment' do
|
it 'returns the current environment' do
|
||||||
expect(env).to receive :some_message
|
expect(env).to receive :some_message
|
||||||
dsl.evaluate env
|
dsl.evaluate
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
describe '#source' do
|
describe '#source' do
|
||||||
let(:filepath) { fixture_path_for 'recipes/throw' }
|
let(:filepath) { fixture_path_for 'recipes/throw' }
|
||||||
let(:code) { "source '#{filepath}'" }
|
let(:code) { "source '#{filepath}'" }
|
||||||
subject(:dsl) { Recipe::DSL.new(code) }
|
subject(:dsl) { Recipe::DSL.new(env, code) }
|
||||||
|
|
||||||
it 'sources the recipe given as argument' do
|
it 'sources the recipe given as argument' do
|
||||||
expect { dsl.evaluate env }.to throw_symbol :recipe_code
|
expect { dsl.evaluate }.to throw_symbol :recipe_code
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
|
Loading…
x
Reference in New Issue
Block a user