diff options
| author | James Turnbull <james@lovedthanlost.net> | 2008-06-17 19:32:50 +1000 |
|---|---|---|
| committer | James Turnbull <james@lovedthanlost.net> | 2008-06-17 19:32:50 +1000 |
| commit | 0f501e327dc767bb09d92429693f51629782065a (patch) | |
| tree | 27902bc7bc772a4eb97ca712808ddd7ae16ba32c | |
| parent | d6943cd6154d80445eeb58721ab2e16bb17bff02 (diff) | |
| parent | 4d9536418d8f684923063eac03d3a59d69bb3794 (diff) | |
Merge branch 'tickets/0.24.x/1221' of git://github.com/lak/puppet into 0.24.x
Conflicts:
CHANGELOG
| -rw-r--r-- | CHANGELOG | 2 | ||||
| -rw-r--r-- | lib/puppet/node/catalog.rb | 7 | ||||
| -rwxr-xr-x | spec/unit/node/catalog.rb | 11 |
3 files changed, 16 insertions, 4 deletions
@@ -2,6 +2,8 @@ Fixed #1367 - Updated Rakefile for new daily builds Fixed #1370 - removed test/util/loadedfile.rb tests + + Fixed #1221 - aliases to titles now work for resources. Fixed #1360 - allowdupe works on groups again. diff --git a/lib/puppet/node/catalog.rb b/lib/puppet/node/catalog.rb index 7d9a83795..720b3752d 100644 --- a/lib/puppet/node/catalog.rb +++ b/lib/puppet/node/catalog.rb @@ -88,8 +88,13 @@ class Puppet::Node::Catalog < Puppet::PGraph resource.ref =~ /^(.+)\[/ newref = "%s[%s]" % [$1 || resource.class.name, name] + + # LAK:NOTE It's important that we directly compare the references, + # because sometimes an alias is created before the resource is + # added to the catalog, so comparing inside the below if block + # isn't sufficient. + return if newref == resource.ref if existing = @resource_table[newref] - return if existing == resource raise(ArgumentError, "Cannot alias %s to %s; resource %s already exists" % [resource.ref, name, newref]) end @resource_table[newref] = resource diff --git a/spec/unit/node/catalog.rb b/spec/unit/node/catalog.rb index ff9ab6930..b4f1503da 100755 --- a/spec/unit/node/catalog.rb +++ b/spec/unit/node/catalog.rb @@ -345,9 +345,9 @@ end describe Puppet::Node::Catalog, " when functioning as a resource container" do before do @catalog = Puppet::Node::Catalog.new("host") - @one = stub 'resource1', :ref => "Me[one]", :catalog= => nil - @two = stub 'resource2', :ref => "Me[two]", :catalog= => nil - @dupe = stub 'resource3', :ref => "Me[one]", :catalog= => nil + @one = stub 'resource1', :ref => "Me[one]", :catalog= => nil, :title => "one" + @two = stub 'resource2', :ref => "Me[two]", :catalog= => nil, :title => "two" + @dupe = stub 'resource3', :ref => "Me[one]", :catalog= => nil, :title => "one" end it "should provide a method to add one or more resources" do @@ -482,6 +482,11 @@ describe Puppet::Node::Catalog, " when functioning as a resource container" do proc { @catalog.alias @one, "one" }.should_not raise_error end + it "should not create aliases that point back to the resource" do + @catalog.alias(@one, "one") + @catalog.resource(:me, "one").should be_nil + end + it "should be able to look resources up by their aliases" do @catalog.add_resource @one @catalog.alias @one, "two" |
