diff options
author | Ashley Penney <ashley.penney@puppetlabs.com> | 2014-03-18 12:34:40 -0400 |
---|---|---|
committer | Ashley Penney <ashley.penney@puppetlabs.com> | 2014-03-18 12:34:40 -0400 |
commit | fec943f441f0c6ab8d6b685091d3418ec0e265b4 (patch) | |
tree | 144aed26b9fb50790708c5b221afdeb32bc03186 /spec/lib/puppet_spec/fixtures.rb | |
parent | 326a8fd801ecba11005189c10ca8749872ef6577 (diff) | |
parent | 9aa28f1c100d7703aa1bb9fbe2bcf02bf781b486 (diff) | |
download | puppet-stdlib-fec943f441f0c6ab8d6b685091d3418ec0e265b4.tar.gz puppet-stdlib-fec943f441f0c6ab8d6b685091d3418ec0e265b4.tar.bz2 |
Merge pull request #231 from apenney/32-testing
Numerous changes to update testing gems.
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 |