
It was not specific to Pacemaker in any way, yet was previously in Chef::RSpec::Pacemaker::CIBObject, in a file alongside other Pacemaker-specific code.
55 lines
1.5 KiB
Ruby
55 lines
1.5 KiB
Ruby
require 'spec_helper'
|
|
|
|
this_dir = File.dirname(__FILE__)
|
|
require File.expand_path('../helpers/runnable_resource', this_dir)
|
|
require File.expand_path('../fixtures/resource_group', this_dir)
|
|
|
|
describe "Chef::Provider::PacemakerGroup" do
|
|
# for use inside examples:
|
|
let(:fixture) { Chef::RSpec::Pacemaker::Config::RESOURCE_GROUP.dup }
|
|
# for use outside examples (e.g. when invoking shared_examples)
|
|
fixture = Chef::RSpec::Pacemaker::Config::RESOURCE_GROUP.dup
|
|
|
|
def lwrp_name
|
|
'group'
|
|
end
|
|
|
|
include_context "a Pacemaker LWRP"
|
|
|
|
before(:each) do
|
|
@resource.members fixture.members.dup
|
|
@resource.meta Hash[fixture.meta.dup]
|
|
|
|
|
|
end
|
|
|
|
def cib_object_class
|
|
Pacemaker::Resource::Group
|
|
end
|
|
|
|
describe ":create action" do
|
|
include Chef::RSpec::Pacemaker::CIBObject
|
|
|
|
it "should modify the group if it has a member resource added" do
|
|
expected = fixture.dup
|
|
expected.members = expected.members.dup + %w(resource3)
|
|
expected_configure_cmd_args = [expected.reconfigure_command]
|
|
test_modify(expected_configure_cmd_args) do
|
|
@resource.members expected.members
|
|
end
|
|
end
|
|
|
|
it "should modify the group if it has different member resources" do
|
|
fixture.members = %w(resource1 resource3)
|
|
expected_configure_cmd_args = [fixture.reconfigure_command]
|
|
test_modify(expected_configure_cmd_args) do
|
|
@resource.members fixture.members
|
|
end
|
|
end
|
|
|
|
end
|
|
|
|
it_should_behave_like "a runnable resource", fixture
|
|
|
|
end
|