Sha256: 28f36fb40f2a43890a931044da092dac6566a4798057277e773bbb202c20f849

Contents?: true

Size: 1.02 KB

Versions: 5

Compression:

Stored size: 1.02 KB

Contents

module Facter
module Util
##
# {Facter::Util::FileRead} is a utility module intended to provide easily
# mockable methods that delegate to simple file read methods.  The intent is to
# avoid the need to execute the `cat` system command or `File.read` directly in
# Ruby, as mocking these behaviors can have wide-ranging effects.
#
# All Facter facts are encouraged to use this method instead of File.read or
# Facter::Util::Resolution.exec('cat ...')
#
# @api public
module FileRead
  ##
  # read returns the raw content of a file as a string.  If the file does not
  # exist, or the process does not have permission to read the file then nil is
  # returned.
  #
  # @api public
  #
  # @return [String] the raw contents of the file at {path} or {nil} if the
  # file cannot be read because it does not exist or the process does not have
  # permission to read the file.
  def self.read(path)
    File.read(path)
  rescue Errno::ENOENT, Errno::EACCES => detail
    Facter.debug "Could not read #{path}: #{detail.message}"
    nil
  end
end
end
end

Version data entries

5 entries across 5 versions & 1 rubygems

Version Path
facter-1.7.1 lib/facter/util/file_read.rb
facter-1.7.1.rc1 lib/facter/util/file_read.rb
facter-1.7.0 lib/facter/util/file_read.rb
facter-1.7.0.rc2 lib/facter/util/file_read.rb
facter-1.7.0.rc1 lib/facter/util/file_read.rb