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/parser.rb | |
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/parser.rb')
-rwxr-xr-x | spec/unit/parser/parser.rb | 26 |
1 files changed, 26 insertions, 0 deletions
diff --git a/spec/unit/parser/parser.rb b/spec/unit/parser/parser.rb index 0092a9970..c0d22a2cc 100755 --- a/spec/unit/parser/parser.rb +++ b/spec/unit/parser/parser.rb @@ -116,4 +116,30 @@ describe Puppet::Parser do end + describe Puppet::Parser, "when parsing if statements" do + + it "should not raise errors with empty if" do + lambda { @parser.parse("if true { }") }.should_not raise_error + end + + it "should not raise errors with empty else" do + lambda { @parser.parse("if false { notice('if') } else { }") }.should_not raise_error + end + + it "should not raise errors with empty if and else" do + lambda { @parser.parse("if false { } else { }") }.should_not raise_error + end + + it "should create a nop node for empty branch" do + AST::Nop.expects(:new) + @parser.parse("if true { }") + end + + it "should create a nop node for empty else branch" do + AST::Nop.expects(:new) + @parser.parse("if true { notice('test') } else { }") + end + + end + end |