summaryrefslogtreecommitdiffstats
path: root/spec/unit/node
diff options
context:
space:
mode:
authorLuke Kanies <luke@madstop.com>2007-10-31 11:34:06 -0500
committerLuke Kanies <luke@madstop.com>2007-10-31 11:34:06 -0500
commit826efe8d453c1cc45a980603fffc10c91fa0e267 (patch)
treed0c216e9f3784b075c0f8f361e0f67885aec430e /spec/unit/node
parentdb293cf3b9e9dd129d8c65aa39272425651addae (diff)
downloadpuppet-826efe8d453c1cc45a980603fffc10c91fa0e267.tar.gz
puppet-826efe8d453c1cc45a980603fffc10c91fa0e267.tar.xz
puppet-826efe8d453c1cc45a980603fffc10c91fa0e267.zip
The configurations should now be functional again --
file recursion was previously not working, because the relationship graph was setting itself as a resource's primary configuration, which caused it to try creating its own relationship graph. I've now found that the current code is about 5x slower than the released code, so now I hope to resolve that.
Diffstat (limited to 'spec/unit/node')
-rwxr-xr-xspec/unit/node/configuration.rb27
1 files changed, 27 insertions, 0 deletions
diff --git a/spec/unit/node/configuration.rb b/spec/unit/node/configuration.rb
index 5f807b9b6..e9dc6b85d 100755
--- a/spec/unit/node/configuration.rb
+++ b/spec/unit/node/configuration.rb
@@ -312,6 +312,17 @@ describe Puppet::Node::Configuration, " when functioning as a resource container
@config.resource(@two.ref).should equal(@two)
end
+ it "should set itself as the resource's configuration if it is not a relationship graph" do
+ @one.expects(:configuration=).with(@config)
+ @config.add_resource @one
+ end
+
+ it "should not set itself as the resource's configuration if it is a relationship graph" do
+ @one.expects(:configuration=).never
+ @config.is_relationship_graph = true
+ @config.add_resource @one
+ end
+
it "should make all vertices available by resource reference" do
@config.add_resource(@one)
@config.resource(@one.ref).should equal(@one)
@@ -516,6 +527,10 @@ describe Puppet::Node::Configuration, " when creating a relationship graph" do
@relationships = @config.relationship_graph
end
+ it "should fail when trying to create a relationship graph for a relationship graph" do
+ proc { @relationships.relationship_graph }.should raise_error(Puppet::DevError)
+ end
+
it "should be able to create a relationship graph" do
@relationships.should be_instance_of(Puppet::Node::Configuration)
end
@@ -578,6 +593,18 @@ describe Puppet::Node::Configuration, " when creating a relationship graph" do
@config.resource("File[/yay]").should equal(resource)
end
+ it "should add implicit resources to the relationship graph if there is one" do
+ args = {:name => "/yay", :ensure => :file}
+ resource = stub 'file', :ref => "File[/yay]", :configuration= => @config
+ resource.expects(:implicit=).with(true)
+ Puppet::Type.type(:file).expects(:create).with(args).returns(resource)
+ # build the graph
+ relgraph = @config.relationship_graph
+
+ @config.create_implicit_resource :file, args
+ relgraph.resource("File[/yay]").should equal(resource)
+ end
+
it "should remove resources created mid-transaction" do
args = {:name => "/yay", :ensure => :file}
resource = stub 'file', :ref => "File[/yay]", :configuration= => @config