make fixture variable name generic to facilitate code reuse

This commit is contained in:
Adam Spiers
2014-02-06 10:36:30 +00:00
parent 6f962abf55
commit a2e9b7f018
2 changed files with 52 additions and 52 deletions

View File

@@ -5,9 +5,9 @@ require File.join(File.dirname(__FILE__), %w(.. fixtures colocation_constraint))
describe "Chef::Provider::PacemakerColocation" do
# for use inside examples:
let(:colo) { Chef::RSpec::Pacemaker::Config::COLOCATION_CONSTRAINT.dup }
let(:fixture) { Chef::RSpec::Pacemaker::Config::COLOCATION_CONSTRAINT.dup }
# for use outside examples (e.g. when invoking shared_examples)
colo = Chef::RSpec::Pacemaker::Config::COLOCATION_CONSTRAINT.dup
fixture = Chef::RSpec::Pacemaker::Config::COLOCATION_CONSTRAINT.dup
before(:each) do
runner_opts = {
@@ -18,9 +18,9 @@ describe "Chef::Provider::PacemakerColocation" do
@node = @chef_run.node
@run_context = @chef_run.run_context
@resource = Chef::Resource::PacemakerColocation.new(colo.name, @run_context)
@resource.score colo.score
@resource.resources colo.resources.dup
@resource = Chef::Resource::PacemakerColocation.new(fixture.name, @run_context)
@resource.score fixture.score
@resource.resources fixture.resources.dup
end
let (:provider) { Chef::Provider::PacemakerColocation.new(@resource, @run_context) }
@@ -35,7 +35,7 @@ describe "Chef::Provider::PacemakerColocation" do
def test_modify(expected_cmds)
yield
expect_definition(colo.definition_string)
expect_definition(fixture.definition_string)
provider.run_action :create
@@ -47,8 +47,8 @@ describe "Chef::Provider::PacemakerColocation" do
it "should modify the constraint if it has a different score" do
new_score = '100'
colo.score = new_score
expected_configure_cmd_args = [colo.reconfigure_command]
fixture.score = new_score
expected_configure_cmd_args = [fixture.reconfigure_command]
test_modify(expected_configure_cmd_args) do
@resource.score new_score
end
@@ -56,7 +56,7 @@ describe "Chef::Provider::PacemakerColocation" do
it "should modify the constraint if it has a resource added" do
new_resource = 'bar:Stopped'
expected = colo.dup
expected = fixture.dup
expected.resources = expected.resources.dup + [new_resource]
expected_configure_cmd_args = [expected.reconfigure_command]
test_modify(expected_configure_cmd_args) do
@@ -66,8 +66,8 @@ describe "Chef::Provider::PacemakerColocation" do
it "should modify the constraint if it has a different resource" do
new_resources = ['bar:Started']
colo.resources = new_resources
expected_configure_cmd_args = [colo.reconfigure_command]
fixture.resources = new_resources
expected_configure_cmd_args = [fixture.reconfigure_command]
test_modify(expected_configure_cmd_args) do
@resource.resources new_resources
end
@@ -77,7 +77,7 @@ describe "Chef::Provider::PacemakerColocation" do
describe ":delete action" do
it_should_behave_like "action on non-existent resource", \
:delete, "crm configure delete #{colo.name}", nil
:delete, "crm configure delete #{fixture.name}", nil
end
end

View File

@@ -5,9 +5,9 @@ require File.join(File.dirname(__FILE__), %w(.. fixtures keystone_primitive))
describe "Chef::Provider::PacemakerPrimitive" do
# for use inside examples:
let(:rsc) { Chef::RSpec::Pacemaker::Config::KEYSTONE_PRIMITIVE }
let(:fixture) { Chef::RSpec::Pacemaker::Config::KEYSTONE_PRIMITIVE }
# for use outside examples (e.g. when invoking shared_examples)
rsc = Chef::RSpec::Pacemaker::Config::KEYSTONE_PRIMITIVE
fixture = Chef::RSpec::Pacemaker::Config::KEYSTONE_PRIMITIVE
before(:each) do
runner_opts = {
@@ -18,11 +18,11 @@ describe "Chef::Provider::PacemakerPrimitive" do
@node = @chef_run.node
@run_context = @chef_run.run_context
@resource = Chef::Resource::PacemakerPrimitive.new(rsc.name, @run_context)
@resource.agent rsc.agent
@resource.params Hash[rsc.params]
@resource.meta Hash[rsc.meta]
@resource.op Hash[rsc.op]
@resource = Chef::Resource::PacemakerPrimitive.new(fixture.name, @run_context)
@resource.agent fixture.agent
@resource.params Hash[fixture.params]
@resource.meta Hash[fixture.meta]
@resource.op Hash[fixture.op]
end
let (:provider) { Chef::Provider::PacemakerPrimitive.new(@resource, @run_context) }
@@ -43,7 +43,7 @@ describe "Chef::Provider::PacemakerPrimitive" do
def test_modify(expected_cmds)
yield
expect_definition(rsc.definition_string)
expect_definition(fixture.definition_string)
provider.run_action :create
@@ -57,22 +57,22 @@ describe "Chef::Provider::PacemakerPrimitive" do
expected_configure_cmd_args = [
%'--set-parameter "os_password" --parameter-value "newpasswd"',
%'--delete-parameter "os_tenant_name"',
].map { |args| "crm_resource --resource #{rsc.name} #{args}" }
].map { |args| "crm_resource --resource #{fixture.name} #{args}" }
test_modify(expected_configure_cmd_args) do
new_params = Hash[rsc.params].merge("os_password" => "newpasswd")
new_params = Hash[fixture.params].merge("os_password" => "newpasswd")
new_params.delete("os_tenant_name")
@resource.params new_params
@resource.meta Hash[rsc.meta].merge("target-role" => "Stopped")
@resource.meta Hash[fixture.meta].merge("target-role" => "Stopped")
end
end
it "should modify the primitive if it has different meta" do
expected_configure_cmd_args = [
%'--set-parameter "target-role" --parameter-value "Stopped" --meta',
].map { |args| "crm_resource --resource #{rsc.name} #{args}" }
].map { |args| "crm_resource --resource #{fixture.name} #{args}" }
test_modify(expected_configure_cmd_args) do
@resource.params Hash[rsc.params]
@resource.meta Hash[rsc.meta].merge("target-role" => "Stopped")
@resource.params Hash[fixture.params]
@resource.meta Hash[fixture.meta].merge("target-role" => "Stopped")
end
end
@@ -81,21 +81,21 @@ describe "Chef::Provider::PacemakerPrimitive" do
%'--set-parameter "os_password" --parameter-value "newpasswd"',
%'--delete-parameter "os_tenant_name"',
%'--set-parameter "target-role" --parameter-value "Stopped" --meta',
].map { |args| "crm_resource --resource #{rsc.name} #{args}" }
].map { |args| "crm_resource --resource #{fixture.name} #{args}" }
test_modify(expected_configure_cmd_args) do
new_params = Hash[rsc.params].merge("os_password" => "newpasswd")
new_params = Hash[fixture.params].merge("os_password" => "newpasswd")
new_params.delete("os_tenant_name")
@resource.params new_params
@resource.meta Hash[rsc.meta].merge("target-role" => "Stopped")
@resource.meta Hash[fixture.meta].merge("target-role" => "Stopped")
end
end
it "should modify the primitive if it has different op values" do
expected_configure_cmd_args = [
rsc.reconfigure_command.gsub('60', '120')
fixture.reconfigure_command.gsub('60', '120')
]
test_modify(expected_configure_cmd_args) do
new_op = Hash[rsc.op]
new_op = Hash[fixture.op]
# Ensure we're not modifying our expectation as well as the input
new_op['monitor'] = new_op['monitor'].dup
new_op['monitor']['timeout'] = '120'
@@ -111,17 +111,17 @@ describe "Chef::Provider::PacemakerPrimitive" do
provider.run_action :create
expect(@chef_run).to run_execute(rsc.crm_configure_command)
expect(@chef_run).to run_execute(fixture.crm_configure_command)
expect(@resource).to be_updated
end
it "should barf if the primitive is already defined with the wrong agent" do
existing_agent = "ocf:openstack:something-else"
definition = rsc.definition_string.sub(rsc.agent, existing_agent)
definition = fixture.definition_string.sub(fixture.agent, existing_agent)
expect_definition(definition)
expected_error = \
"Existing primitive resource '#{rsc.name}' has agent '#{existing_agent}' " \
"Existing primitive resource '#{fixture.name}' has agent '#{existing_agent}' " \
"but recipe wanted '#{@resource.agent}'"
expect { provider.run_action :create }.to \
raise_error(RuntimeError, expected_error)
@@ -132,28 +132,28 @@ describe "Chef::Provider::PacemakerPrimitive" do
describe ":delete action" do
it_should_behave_like "action on non-existent resource", \
:delete, "crm configure delete #{rsc.name}", nil
:delete, "crm configure delete #{fixture.name}", nil
it "should not delete a running resource" do
expect_definition(rsc.definition_string)
expect_definition(fixture.definition_string)
expect_running(true)
expected_error = "Cannot delete running primitive resource '#{rsc.name}'"
expected_error = "Cannot delete running primitive resource '#{fixture.name}'"
expect { provider.run_action :delete }.to \
raise_error(RuntimeError, expected_error)
cmd = "crm configure delete '#{rsc.name}'"
cmd = "crm configure delete '#{fixture.name}'"
expect(@chef_run).not_to run_execute(cmd)
expect(@resource).not_to be_updated
end
it "should delete a non-running resource" do
expect_definition(rsc.definition_string)
expect_definition(fixture.definition_string)
expect_running(false)
provider.run_action :delete
cmd = "crm configure delete '#{rsc.name}'"
cmd = "crm configure delete '#{fixture.name}'"
expect(@chef_run).to run_execute(cmd)
expect(@resource).to be_updated
end
@@ -162,28 +162,28 @@ describe "Chef::Provider::PacemakerPrimitive" do
describe ":start action" do
it_should_behave_like "action on non-existent resource", \
:start,
"crm resource start #{rsc.name}", \
"Cannot start non-existent resource primitive '#{rsc.name}'"
"crm resource start #{fixture.name}", \
"Cannot start non-existent resource primitive '#{fixture.name}'"
it "should do nothing to a started resource" do
expect_definition(rsc.definition_string)
expect_definition(fixture.definition_string)
expect_running(true)
provider.run_action :start
cmd = "crm resource start #{rsc.name}"
cmd = "crm resource start #{fixture.name}"
expect(@chef_run).not_to run_execute(cmd)
expect(@resource).not_to be_updated
end
it "should start a stopped resource" do
config = rsc.definition_string.sub("Started", "Stopped")
config = fixture.definition_string.sub("Started", "Stopped")
expect_definition(config)
expect_running(false)
provider.run_action :start
cmd = "crm resource start '#{rsc.name}'"
cmd = "crm resource start '#{fixture.name}'"
expect(@chef_run).to run_execute(cmd)
expect(@resource).to be_updated
end
@@ -192,27 +192,27 @@ describe "Chef::Provider::PacemakerPrimitive" do
describe ":stop action" do
it_should_behave_like "action on non-existent resource", \
:stop,
"crm resource stop #{rsc.name}", \
"Cannot stop non-existent resource primitive '#{rsc.name}'"
"crm resource stop #{fixture.name}", \
"Cannot stop non-existent resource primitive '#{fixture.name}'"
it "should do nothing to a stopped resource" do
expect_definition(rsc.definition_string)
expect_definition(fixture.definition_string)
expect_running(false)
provider.run_action :stop
cmd = "crm resource start #{rsc.name}"
cmd = "crm resource start #{fixture.name}"
expect(@chef_run).not_to run_execute(cmd)
expect(@resource).not_to be_updated
end
it "should stop a started resource" do
expect_definition(rsc.definition_string)
expect_definition(fixture.definition_string)
expect_running(true)
provider.run_action :stop
cmd = "crm resource stop '#{rsc.name}'"
cmd = "crm resource stop '#{fixture.name}'"
expect(@chef_run).to run_execute(cmd)
expect(@resource).to be_updated
end