summaryrefslogtreecommitdiffstats
path: root/spec/unit/parser/functions_spec.rb
diff options
context:
space:
mode:
Diffstat (limited to 'spec/unit/parser/functions_spec.rb')
-rw-r--r--spec/unit/parser/functions_spec.rb140
1 files changed, 70 insertions, 70 deletions
diff --git a/spec/unit/parser/functions_spec.rb b/spec/unit/parser/functions_spec.rb
index ee551a147..18aee4b65 100644
--- a/spec/unit/parser/functions_spec.rb
+++ b/spec/unit/parser/functions_spec.rb
@@ -4,99 +4,99 @@ require File.dirname(__FILE__) + '/../../spec_helper'
describe Puppet::Parser::Functions do
- after(:each) do
- # Rationale:
- # our various tests will almost all register to Pupet::Parser::Functions
- # a new function called "name". All tests are required to stub Puppet::Parser::Scope
- # so that +no+ new real ruby method are defined.
- # After each test, we want to leave the whole Puppet::Parser::Functions environment
- # as it was before we were called, hence we call rmfunction (which might not succeed
- # if the function hasn't been registered in the test). It is also important in this
- # section to stub +remove_method+ here so that we don't pollute the scope.
- Puppet::Parser::Scope.stubs(:remove_method)
- begin
- Puppet::Parser::Functions.rmfunction("name")
- rescue
- end
+ after(:each) do
+ # Rationale:
+ # our various tests will almost all register to Pupet::Parser::Functions
+ # a new function called "name". All tests are required to stub Puppet::Parser::Scope
+ # so that +no+ new real ruby method are defined.
+ # After each test, we want to leave the whole Puppet::Parser::Functions environment
+ # as it was before we were called, hence we call rmfunction (which might not succeed
+ # if the function hasn't been registered in the test). It is also important in this
+ # section to stub +remove_method+ here so that we don't pollute the scope.
+ Puppet::Parser::Scope.stubs(:remove_method)
+ begin
+ Puppet::Parser::Functions.rmfunction("name")
+ rescue
end
+ end
- it "should have a method for returning an environment-specific module" do
- Puppet::Parser::Functions.environment_module("myenv").should be_instance_of(Module)
- end
+ it "should have a method for returning an environment-specific module" do
+ Puppet::Parser::Functions.environment_module("myenv").should be_instance_of(Module)
+ end
- it "should use the current default environment if no environment is provided" do
- Puppet::Parser::Functions.environment_module.should be_instance_of(Module)
- end
+ it "should use the current default environment if no environment is provided" do
+ Puppet::Parser::Functions.environment_module.should be_instance_of(Module)
+ end
- describe "when calling newfunction" do
- before do
- @module = Module.new
- Puppet::Parser::Functions.stubs(:environment_module).returns @module
- end
+ describe "when calling newfunction" do
+ before do
+ @module = Module.new
+ Puppet::Parser::Functions.stubs(:environment_module).returns @module
+ end
- it "should create the function in the environment module" do
- @module.expects(:define_method).with { |name,block| name == "function_name" }
+ it "should create the function in the environment module" do
+ @module.expects(:define_method).with { |name,block| name == "function_name" }
- Puppet::Parser::Functions.newfunction("name", :type => :rvalue)
- end
+ Puppet::Parser::Functions.newfunction("name", :type => :rvalue)
+ end
- it "should raise an error if the function already exists" do
- @module.expects(:define_method).with { |name,block| name == "function_name" }.once
- Puppet::Parser::Functions.newfunction("name", :type => :rvalue)
+ it "should raise an error if the function already exists" do
+ @module.expects(:define_method).with { |name,block| name == "function_name" }.once
+ Puppet::Parser::Functions.newfunction("name", :type => :rvalue)
- lambda { Puppet::Parser::Functions.newfunction("name", :type => :rvalue) }.should raise_error
- end
+ lambda { Puppet::Parser::Functions.newfunction("name", :type => :rvalue) }.should raise_error
+ end
- it "should raise an error if the function type is not correct" do
- @module.expects(:define_method).with { |name,block| name == "function_name" }.never
+ it "should raise an error if the function type is not correct" do
+ @module.expects(:define_method).with { |name,block| name == "function_name" }.never
- lambda { Puppet::Parser::Functions.newfunction("name", :type => :unknown) }.should raise_error
- end
+ lambda { Puppet::Parser::Functions.newfunction("name", :type => :unknown) }.should raise_error
end
+ end
- describe "when calling rmfunction" do
- before do
- @module = Module.new
- Puppet::Parser::Functions.stubs(:environment_module).returns @module
- end
+ describe "when calling rmfunction" do
+ before do
+ @module = Module.new
+ Puppet::Parser::Functions.stubs(:environment_module).returns @module
+ end
- it "should remove the function in the scope class" do
- @module.expects(:define_method).with { |name,block| name == "function_name" }
- Puppet::Parser::Functions.newfunction("name", :type => :rvalue)
+ it "should remove the function in the scope class" do
+ @module.expects(:define_method).with { |name,block| name == "function_name" }
+ Puppet::Parser::Functions.newfunction("name", :type => :rvalue)
- @module.expects(:remove_method).with("function_name").once
+ @module.expects(:remove_method).with("function_name").once
- Puppet::Parser::Functions.rmfunction("name")
- end
+ Puppet::Parser::Functions.rmfunction("name")
+ end
- it "should raise an error if the function doesn't exists" do
- lambda { Puppet::Parser::Functions.rmfunction("name") }.should raise_error
- end
+ it "should raise an error if the function doesn't exists" do
+ lambda { Puppet::Parser::Functions.rmfunction("name") }.should raise_error
end
+ end
- describe "when calling function to test function existance" do
- before do
- @module = Module.new
- Puppet::Parser::Functions.stubs(:environment_module).returns @module
- end
+ describe "when calling function to test function existance" do
+ before do
+ @module = Module.new
+ Puppet::Parser::Functions.stubs(:environment_module).returns @module
+ end
- it "should return false if the function doesn't exist" do
- Puppet::Parser::Functions.autoloader.stubs(:load)
+ it "should return false if the function doesn't exist" do
+ Puppet::Parser::Functions.autoloader.stubs(:load)
- Puppet::Parser::Functions.function("name").should be_false
- end
+ Puppet::Parser::Functions.function("name").should be_false
+ end
- it "should return its name if the function exists" do
- @module.expects(:define_method).with { |name,block| name == "function_name" }
- Puppet::Parser::Functions.newfunction("name", :type => :rvalue)
+ it "should return its name if the function exists" do
+ @module.expects(:define_method).with { |name,block| name == "function_name" }
+ Puppet::Parser::Functions.newfunction("name", :type => :rvalue)
- Puppet::Parser::Functions.function("name").should == "function_name"
- end
+ Puppet::Parser::Functions.function("name").should == "function_name"
+ end
- it "should try to autoload the function if it doesn't exist yet" do
- Puppet::Parser::Functions.autoloader.expects(:load)
+ it "should try to autoload the function if it doesn't exist yet" do
+ Puppet::Parser::Functions.autoloader.expects(:load)
- Puppet::Parser::Functions.function("name")
- end
+ Puppet::Parser::Functions.function("name")
end
+ end
end