Module: PuppetlabsSpec::Fixtures

Defined in:
lib/puppetlabs_spec_helper/puppetlabs_spec/fixtures.rb

Overview

This module provides some helper methods to assist with fixtures. It’s methods are designed to help when you have a conforming fixture layout so we get project consistency.

Instance Method Summary collapse

Instance Method Details

#fixtures(*rest) ⇒ Object

Returns the joined path of the global FIXTURE_DIR plus any path given to it



7
8
9
# File 'lib/puppetlabs_spec_helper/puppetlabs_spec/fixtures.rb', line 7

def fixtures(*rest)
  File.join(PuppetlabsSpec::FIXTURE_DIR, *rest)
end

#my_fixture(name) ⇒ Object

Given a name, returns the full path of a file from your relative fixture dir as returned by my_fixture_dir.



25
26
27
28
29
30
31
# File 'lib/puppetlabs_spec_helper/puppetlabs_spec/fixtures.rb', line 25

def my_fixture(name)
  file = File.join(my_fixture_dir, name)
  unless File.readable? file then
    fail "fixture '#{name}' for #{my_fixture_dir} is not readable"
  end
  return file
end

#my_fixture_dirObject

Returns the path to your relative fixture dir. So if your spec test is <project>/spec/unit/facter/foo_spec.rb then your relative dir will be <project>/spec/fixture/unit/facter/foo



14
15
16
17
18
19
20
21
# File 'lib/puppetlabs_spec_helper/puppetlabs_spec/fixtures.rb', line 14

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

#my_fixture_read(name) ⇒ Object

Return the contents of the file using read when given a name. Uses my_fixture to work out the relative path.



35
36
37
# File 'lib/puppetlabs_spec_helper/puppetlabs_spec/fixtures.rb', line 35

def my_fixture_read(name)
  File.read(my_fixture(name))
end

#my_fixtures(glob = '*', flags = 0) ⇒ Object

Provides a block mechanism for iterating across the files in your fixture area.



41
42
43
44
45
46
47
48
# File 'lib/puppetlabs_spec_helper/puppetlabs_spec/fixtures.rb', line 41

def my_fixtures(glob = '*', flags = 0)
  files = Dir.glob(File.join(my_fixture_dir, glob), flags)
  unless files.length > 0 then
    fail "fixture '#{glob}' for #{my_fixture_dir} had no files!"
  end
  block_given? and files.each do |file| yield file end
  files
end