require 'spec_helper' describe Ridley::NodeObject do let(:resource) { double('resource') } let(:instance) { described_class.new(resource) } subject { instance } describe "#chef_attributes" do subject { instance.chef_attributes } it "returns a Hashie::Mash" do expect(subject).to be_a(Hashie::Mash) end it "includes default attributes" do instance.default = default = { "default" => { "one" => "val", "two" => "val" } } expect(subject.to_hash).to include(default) end it "includes normal attributes" do instance.normal = normal = { "normal" => { "one" => "val", "two" => "val" } } expect(subject.to_hash).to include(normal) end it "includes override attributes" do instance.override = override = { "override" => { "one" => "val", "two" => "val" } } expect(subject.to_hash).to include(override) end it "includes automatic attributes" do instance.automatic = automatic = { "automatic" => { "one" => "val", "two" => "val" } } expect(subject.to_hash).to include(automatic) end it "overrides default attributes with normal attributes" do instance.default = default = { one: "old", two: "old" } instance.normal = normal = { one: "new" } expect(subject[:one]).to eql("new") expect(subject[:two]).to eql("old") end it "overrides normal attributes with override attributes" do instance.normal = normal = { one: "old", two: "old" } instance.override = override = { one: "new" } expect(subject[:one]).to eql("new") expect(subject[:two]).to eql("old") end it "overrides override attributes with automatic attributes" do instance.override = override = { one: "old", two: "old" } instance.automatic = automatic = { one: "new" } expect(subject[:one]).to eql("new") expect(subject[:two]).to eql("old") end end describe "#set_chef_attribute" do it "sets an normal node attribute at the nested path" do subject.set_chef_attribute('deep.nested.item', true) subject.normal.should have_key("deep") subject.normal["deep"].should have_key("nested") subject.normal["deep"]["nested"].should have_key("item") subject.normal["deep"]["nested"]["item"].should be_true end context "when the normal attribute is already set" do it "test" do subject.normal = { deep: { nested: { item: false } } } subject.set_chef_attribute('deep.nested.item', true) subject.normal["deep"]["nested"]["item"].should be_true end end end describe "#cloud?" do it "returns true if the cloud automatic attribute is set" do subject.automatic = { "cloud" => Hash.new } subject.cloud?.should be_true end it "returns false if the cloud automatic attribute is not set" do subject.automatic.delete(:cloud) subject.cloud?.should be_false end end describe "#eucalyptus?" do it "returns true if the node is a cloud node using the eucalyptus provider" do subject.automatic = { "cloud" => { "provider" => "eucalyptus" } } subject.eucalyptus?.should be_true end it "returns false if the node is not a cloud node" do subject.automatic.delete(:cloud) subject.eucalyptus?.should be_false end it "returns false if the node is a cloud node but not using the eucalyptus provider" do subject.automatic = { "cloud" => { "provider" => "ec2" } } subject.eucalyptus?.should be_false end end describe "#ec2?" do it "returns true if the node is a cloud node using the ec2 provider" do subject.automatic = { "cloud" => { "provider" => "ec2" } } subject.ec2?.should be_true end it "returns false if the node is not a cloud node" do subject.automatic.delete(:cloud) subject.ec2?.should be_false end it "returns false if the node is a cloud node but not using the ec2 provider" do subject.automatic = { "cloud" => { "provider" => "rackspace" } } subject.ec2?.should be_false end end describe "#rackspace?" do it "returns true if the node is a cloud node using the rackspace provider" do subject.automatic = { "cloud" => { "provider" => "rackspace" } } subject.rackspace?.should be_true end it "returns false if the node is not a cloud node" do subject.automatic.delete(:cloud) subject.rackspace?.should be_false end it "returns false if the node is a cloud node but not using the rackspace provider" do subject.automatic = { "cloud" => { "provider" => "ec2" } } subject.rackspace?.should be_false end end describe "#cloud_provider" do it "returns the cloud provider if the node is a cloud node" do subject.automatic = { "cloud" => { "provider" => "ec2" } } subject.cloud_provider.should eql("ec2") end it "returns nil if the node is not a cloud node" do subject.automatic.delete(:cloud) subject.cloud_provider.should be_nil end end describe "#public_ipv4" do it "returns the public ipv4 address if the node is a cloud node" do subject.automatic = { "cloud" => { "provider" => "ec2", "public_ipv4" => "10.0.0.1" } } subject.public_ipv4.should eql("10.0.0.1") end it "returns the ipaddress if the node is not a cloud node" do subject.automatic = { "ipaddress" => "192.168.1.1" } subject.automatic.delete(:cloud) subject.public_ipv4.should eql("192.168.1.1") end end describe "#public_hostname" do it "returns the public hostname if the node is a cloud node" do subject.automatic = { "cloud" => { "public_hostname" => "reset.cloud.riotgames.com" } } subject.public_hostname.should eql("reset.cloud.riotgames.com") end it "returns the FQDN if the node is not a cloud node" do subject.automatic = { "fqdn" => "reset.internal.riotgames.com" } subject.automatic.delete(:cloud) subject.public_hostname.should eql("reset.internal.riotgames.com") end end describe "#chef_run" do it "sends the message #chef_run to the resource with the public_hostname of this instance" do resource.should_receive(:chef_run).with(instance.public_hostname) subject.chef_run end end describe "#put_secret" do it "sends the message #put_secret to the resource with the public_hostname of this instance" do resource.should_receive(:put_secret).with(instance.public_hostname) subject.put_secret end end describe "#merge_data" do before(:each) { subject.name = "reset.riotgames.com" } it "appends items to the run_list" do subject.merge_data(run_list: ["cook::one", "cook::two"]) subject.run_list.should =~ ["cook::one", "cook::two"] end it "ensures the run_list is unique if identical items are given" do subject.run_list = [ "cook::one" ] subject.merge_data(run_list: ["cook::one", "cook::two"]) subject.run_list.should =~ ["cook::one", "cook::two"] end it "deep merges attributes into the normal attributes" do subject.normal = { one: { two: { four: :deep } } } subject.merge_data(attributes: { one: { two: { three: :deep } } }) subject.normal[:one][:two].should have_key(:four) subject.normal[:one][:two][:four].should eql(:deep) subject.normal[:one][:two].should have_key(:three) subject.normal[:one][:two][:three].should eql(:deep) end end end