diff options
Diffstat (limited to 'spec/unit/parser/methods/slice_spec.rb')
-rw-r--r-- | spec/unit/parser/methods/slice_spec.rb | 135 |
1 files changed, 0 insertions, 135 deletions
diff --git a/spec/unit/parser/methods/slice_spec.rb b/spec/unit/parser/methods/slice_spec.rb deleted file mode 100644 index 1de1dd0f1..000000000 --- a/spec/unit/parser/methods/slice_spec.rb +++ /dev/null @@ -1,135 +0,0 @@ -require 'puppet' -require 'spec_helper' -require 'puppet_spec/compiler' -require 'rubygems' - -describe 'methods' do - include PuppetSpec::Compiler - - before :all do - # enable switching back - @saved_parser = Puppet[:parser] - # These tests only work with future parser - Puppet[:parser] = 'future' - end - after :all do - # switch back to original - Puppet[:parser] = @saved_parser - end - - before :each do - node = Puppet::Node.new("floppy", :environment => 'production') - @compiler = Puppet::Parser::Compiler.new(node) - @scope = Puppet::Parser::Scope.new(@compiler) - @topscope = @scope.compiler.topscope - @scope.parent = @topscope - Puppet[:parser] = 'future' - end - - context "should be callable on array as" do - - it 'slice with explicit parameters' do - catalog = compile_to_catalog(<<-MANIFEST) - $a = [1, present, 2, absent, 3, present] - $a.slice(2) |$k,$v| { - file { "/file_${$k}": ensure => $v } - } - MANIFEST - - catalog.resource(:file, "/file_1")['ensure'].should == 'present' - catalog.resource(:file, "/file_2")['ensure'].should == 'absent' - catalog.resource(:file, "/file_3")['ensure'].should == 'present' - end - - it 'slice with one parameter' do - catalog = compile_to_catalog(<<-MANIFEST) - $a = [1, present, 2, absent, 3, present] - $a.slice(2) |$k| { - file { "/file_${$k[0]}": ensure => $k[1] } - } - MANIFEST - - catalog.resource(:file, "/file_1")['ensure'].should == 'present' - catalog.resource(:file, "/file_2")['ensure'].should == 'absent' - catalog.resource(:file, "/file_3")['ensure'].should == 'present' - end - - it 'slice with shorter last slice' do - catalog = compile_to_catalog(<<-MANIFEST) - $a = [1, present, 2, present, 3, absent] - $a.slice(4) |$a, $b, $c, $d| { - file { "/file_$a.$c": ensure => $b } - } - MANIFEST - - catalog.resource(:file, "/file_1.2")['ensure'].should == 'present' - catalog.resource(:file, "/file_3.")['ensure'].should == 'absent' - end - end - - context "should be callable on hash as" do - it 'slice with explicit parameters, missing are empty' do - catalog = compile_to_catalog(<<-MANIFEST) - $a = {1=>present, 2=>present, 3=>absent} - $a.slice(2) |$a,$b| { - file { "/file_${a[0]}.${b[0]}": ensure => $a[1] } - } - MANIFEST - - catalog.resource(:file, "/file_1.2")['ensure'].should == 'present' - catalog.resource(:file, "/file_3.")['ensure'].should == 'absent' - end - end - - context "should be callable on enumerable types as" do - it 'slice with integer range' do - catalog = compile_to_catalog(<<-MANIFEST) - $a = Integer[1,4] - $a.slice(2) |$a,$b| { - file { "/file_${a}.${b}": ensure => present } - } - MANIFEST - - catalog.resource(:file, "/file_1.2")['ensure'].should == 'present' - catalog.resource(:file, "/file_3.4")['ensure'].should == 'present' - end - - it 'slice with integer' do - catalog = compile_to_catalog(<<-MANIFEST) - 4.slice(2) |$a,$b| { - file { "/file_${a}.${b}": ensure => present } - } - MANIFEST - - catalog.resource(:file, "/file_0.1")['ensure'].should == 'present' - catalog.resource(:file, "/file_2.3")['ensure'].should == 'present' - end - - it 'slice with string' do - catalog = compile_to_catalog(<<-MANIFEST) - 'abcd'.slice(2) |$a,$b| { - file { "/file_${a}.${b}": ensure => present } - } - MANIFEST - - catalog.resource(:file, "/file_a.b")['ensure'].should == 'present' - catalog.resource(:file, "/file_c.d")['ensure'].should == 'present' - end - end - - context "when called without a block" do - it "should produce an array with the result" do - catalog = compile_to_catalog(<<-MANIFEST) - $a = [1, present, 2, absent, 3, present] - $a.slice(2).each |$k| { - file { "/file_${$k[0]}": ensure => $k[1] } - } - MANIFEST - - catalog.resource(:file, "/file_1")['ensure'].should == 'present' - catalog.resource(:file, "/file_2")['ensure'].should == 'absent' - catalog.resource(:file, "/file_3")['ensure'].should == 'present' - - end - end -end |