diff options
author | Hunter Haugen <hunter@puppetlabs.com> | 2014-03-18 16:16:00 -0700 |
---|---|---|
committer | Hunter Haugen <hunter@puppetlabs.com> | 2014-03-18 16:16:00 -0700 |
commit | 904f1a003e790ba2afaf3452ecda9805e87d80d0 (patch) | |
tree | 93407d68868c37af5d597d33134ba5a16e919a21 /spec/lib/puppet_spec/fixtures.rb | |
parent | db00ce660520abfdc110d1ed0dd10bfbc708e256 (diff) | |
parent | fec943f441f0c6ab8d6b685091d3418ec0e265b4 (diff) | |
download | puppet-stdlib-904f1a003e790ba2afaf3452ecda9805e87d80d0.tar.gz puppet-stdlib-904f1a003e790ba2afaf3452ecda9805e87d80d0.tar.bz2 |
Merge branch '3.2.x' into 3.x
Diffstat (limited to 'spec/lib/puppet_spec/fixtures.rb')
-rwxr-xr-x | spec/lib/puppet_spec/fixtures.rb | 28 |
1 files changed, 28 insertions, 0 deletions
diff --git a/spec/lib/puppet_spec/fixtures.rb b/spec/lib/puppet_spec/fixtures.rb new file mode 100755 index 0000000..7f6bc2a --- /dev/null +++ b/spec/lib/puppet_spec/fixtures.rb @@ -0,0 +1,28 @@ +module PuppetSpec::Fixtures + def fixtures(*rest) + File.join(PuppetSpec::FIXTURE_DIR, *rest) + end + def my_fixture_dir + callers = caller + while line = callers.shift do + next unless found = line.match(%r{/spec/(.*)_spec\.rb:}) + return fixtures(found[1]) + end + fail "sorry, I couldn't work out your path from the caller stack!" + end + def my_fixture(name) + file = File.join(my_fixture_dir, name) + unless File.readable? file then + fail Puppet::DevError, "fixture '#{name}' for #{my_fixture_dir} is not readable" + end + return file + end + def my_fixtures(glob = '*', flags = 0) + files = Dir.glob(File.join(my_fixture_dir, glob), flags) + unless files.length > 0 then + fail Puppet::DevError, "fixture '#{glob}' for #{my_fixture_dir} had no files!" + end + block_given? and files.each do |file| yield file end + files + end +end |