diff options
| author | Brice Figureau <brice-puppet@daysofwonder.com> | 2008-10-04 16:11:03 +0200 |
|---|---|---|
| committer | James Turnbull <james@lovedthanlost.net> | 2008-10-07 07:51:44 +1100 |
| commit | 0c297be5dad784e305ef194cee29b11a92d31b6b (patch) | |
| tree | 947b3bdb076461f53278be3a1fad39ee4fc5bed6 /spec/unit/parser/ast | |
| parent | 5268487ac862eec6381d315800d6f56c51dc57b5 (diff) | |
| download | puppet-0c297be5dad784e305ef194cee29b11a92d31b6b.tar.gz puppet-0c297be5dad784e305ef194cee29b11a92d31b6b.tar.xz puppet-0c297be5dad784e305ef194cee29b11a92d31b6b.zip | |
Fix #1109 - allow empty if or else branches
This changesets allow empty if or else branches:
if true {
} else {
}
It works by emitting on the parser stack an AST node that doesn't
do anything (a no-op). This allows the less intrusive code
as no part of the if evaluation code has been touched.
Diffstat (limited to 'spec/unit/parser/ast')
| -rwxr-xr-x | spec/unit/parser/ast/nop.rb | 20 |
1 files changed, 20 insertions, 0 deletions
diff --git a/spec/unit/parser/ast/nop.rb b/spec/unit/parser/ast/nop.rb new file mode 100755 index 000000000..5a7132586 --- /dev/null +++ b/spec/unit/parser/ast/nop.rb @@ -0,0 +1,20 @@ +#!/usr/bin/env ruby + +require File.dirname(__FILE__) + '/../../../spec_helper' + +describe Puppet::Parser::AST::Nop do + + before do + @scope = mock 'scope' + end + + it "should do nothing on evaluation" do + Puppet::Parser::AST.expects(:safeevaluate).never + Puppet::Parser::AST::Nop.new({}).evaluate(@scope) + end + + it "should not return anything" do + Puppet::Parser::AST::Nop.new({}).evaluate(@scope).should be_nil + end + +end |
