summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--lib/puppet/parser/loaded_code.rb85
-rw-r--r--spec/unit/parser/loaded_code.rb106
2 files changed, 191 insertions, 0 deletions
diff --git a/lib/puppet/parser/loaded_code.rb b/lib/puppet/parser/loaded_code.rb
new file mode 100644
index 000000000..7c918d4c3
--- /dev/null
+++ b/lib/puppet/parser/loaded_code.rb
@@ -0,0 +1,85 @@
+class Puppet::Parser::LoadedCode
+ def initialize
+ @hostclasses = {}
+ @definitions = {}
+ @nodes = {}
+ end
+
+ def add_hostclass(name, code)
+ @hostclasses[munge_name(name)] = code
+ end
+
+ def hostclass(name)
+ @hostclasses[munge_name(name)]
+ end
+
+ def add_node(name, code)
+ @nodes[munge_name(name)] = code
+ end
+
+ def node(name)
+ @nodes[munge_name(name)]
+ end
+
+ def nodes?
+ @nodes.length > 0
+ end
+
+ def add_definition(name, code)
+ @definitions[munge_name(name)] = code
+ end
+
+ def definition(name)
+ @definitions[munge_name(name)]
+ end
+
+ def find(namespace, name, type)
+ if r = find_fully_qualified(name, type)
+ return r
+ end
+
+ ary = namespace.split("::")
+
+ while ary.length > 0
+ tmp_namespace = ary.join("::")
+ if r = find_partially_qualified(tmp_namespace, name, type)
+ return r
+ end
+
+ # Delete the second to last object, which reduces our namespace by one.
+ ary.pop
+ end
+
+ send(type, name)
+ end
+
+ def find_node(name)
+ find("", name, :node)
+ end
+
+ def find_hostclass(namespace, name)
+ find(namespace, name, :hostclass)
+ end
+
+ def find_definition(namespace, name)
+ find(namespace, name, :definition)
+ end
+
+ private
+
+ def find_fully_qualified(name, type)
+ return nil unless name =~ /^::/
+
+ name = name.sub(/^::/, '')
+
+ send(type, name)
+ end
+
+ def find_partially_qualified(namespace, name, type)
+ send(type, [namespace, name].join("::"))
+ end
+
+ def munge_name(name)
+ name.to_s.downcase
+ end
+end
diff --git a/spec/unit/parser/loaded_code.rb b/spec/unit/parser/loaded_code.rb
new file mode 100644
index 000000000..50f6b930c
--- /dev/null
+++ b/spec/unit/parser/loaded_code.rb
@@ -0,0 +1,106 @@
+#!/usr/bin/env ruby
+
+require File.dirname(__FILE__) + '/../../spec_helper'
+
+require 'puppet/parser/loaded_code'
+
+describe Puppet::Parser::LoadedCode do
+ %w{hostclass node definition}.each do |data|
+ it "should have a method for adding a #{data}" do
+ Puppet::Parser::LoadedCode.new.should respond_to("add_" + data)
+ end
+
+ it "should be able to retrieve #{data} by name" do
+ loader = Puppet::Parser::LoadedCode.new
+ loader.send("add_" + data, "foo", "bar")
+ loader.send(data, "foo").should == "bar"
+ end
+
+ it "should retrieve #{data} insensitive to case" do
+ loader = Puppet::Parser::LoadedCode.new
+ loader.send("add_" + data, "Foo", "bar")
+ loader.send(data, "fOo").should == "bar"
+ end
+
+ it "should return nil when asked for a #{data} that has not been added" do
+ Puppet::Parser::LoadedCode.new.send(data, "foo").should be_nil
+ end
+ end
+
+ describe "when finding a qualified instance" do
+ it "should return any found instance if the instance name is fully qualified" do
+ loader = Puppet::Parser::LoadedCode.new
+ loader.add_node "foo::bar", "yay"
+ loader.find("namespace", "::foo::bar", :node).should == "yay"
+ end
+
+ it "should return nil if the instance name is fully qualified and no such instance exists" do
+ loader = Puppet::Parser::LoadedCode.new
+ loader.find("namespace", "::foo::bar", :node).should be_nil
+ end
+
+ it "should return the partially qualified object if it exists in the provided namespace" do
+ loader = Puppet::Parser::LoadedCode.new
+ loader.add_node "foo::bar::baz", "yay"
+ loader.find("foo", "bar::baz", :node).should == "yay"
+ end
+
+ it "should return the unqualified object if it exists in the provided namespace" do
+ loader = Puppet::Parser::LoadedCode.new
+ loader.add_node "foo::bar", "yay"
+ loader.find("foo", "bar", :node).should == "yay"
+ end
+
+ it "should return the unqualified object if it exists in the parent namespace" do
+ loader = Puppet::Parser::LoadedCode.new
+ loader.add_node "foo::bar", "yay"
+ loader.find("foo::bar::baz", "bar", :node).should == "yay"
+ end
+
+ it "should should return the partially qualified object if it exists in the parent namespace" do
+ loader = Puppet::Parser::LoadedCode.new
+ loader.add_node "foo::bar::baz", "yay"
+ loader.find("foo::bar", "bar::baz", :node).should == "yay"
+ end
+
+ it "should return the qualified object if it exists in the root namespace" do
+ loader = Puppet::Parser::LoadedCode.new
+ loader.add_node "foo::bar::baz", "yay"
+ loader.find("foo::bar", "foo::bar::baz", :node).should == "yay"
+ end
+
+ it "should return nil if the object cannot be found" do
+ loader = Puppet::Parser::LoadedCode.new
+ loader.add_node "foo::bar::baz", "yay"
+ loader.find("foo::bar", "eh", :node).should be_nil
+ end
+ end
+
+ it "should use the generic 'find' method with an empty namespace to find nodes" do
+ loader = Puppet::Parser::LoadedCode.new
+ loader.expects(:find).with("", "bar", :node)
+ loader.find_node("bar")
+ end
+
+ it "should use the generic 'find' method to find hostclasses" do
+ loader = Puppet::Parser::LoadedCode.new
+ loader.expects(:find).with("foo", "bar", :hostclass)
+ loader.find_hostclass("foo", "bar")
+ end
+
+ it "should use the generic 'find' method to find definitions" do
+ loader = Puppet::Parser::LoadedCode.new
+ loader.expects(:find).with("foo", "bar", :definition)
+ loader.find_definition("foo", "bar")
+ end
+
+ it "should indicate whether any nodes are defined" do
+ loader = Puppet::Parser::LoadedCode.new
+ loader.add_node("foo", "bar")
+ loader.should be_nodes
+ end
+
+ it "should indicate whether no nodes are defined" do
+ Puppet::Parser::LoadedCode.new.should_not be_nodes
+ end
+end