summaryrefslogtreecommitdiff
path: root/spec/unit/parser/methods/slice_spec.rb
diff options
context:
space:
mode:
Diffstat (limited to 'spec/unit/parser/methods/slice_spec.rb')
-rw-r--r--spec/unit/parser/methods/slice_spec.rb135
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