module FakeFS::FileSystem

FileSystem module

Public Instance Methods

add(path, object = FakeDir.new) click to toggle source
# File lib/fakefs/file_system.rb, line 39
def add(path, object = FakeDir.new)
  parts = path_parts(normalize_path(path))

  d = parts[0...-1].reduce(fs) do |dir, part|
    assert_dir dir[part] if dir[part]
    dir[part] ||= FakeDir.new(part, dir)
  end

  assert_dir d
  object.name = parts.last
  object.parent = d
  d[parts.last] ||= object
end
chdir(dir) { |dir| ... } click to toggle source
# File lib/fakefs/file_system.rb, line 86
def chdir(dir, &blk)
  new_dir = find(dir)
  dir_levels.push dir.to_s if blk

  raise Errno::ENOENT, dir.to_s unless new_dir
  raise Errno::ENOTDIR, dir.to_s unless File.directory? new_dir

  dir_levels.push dir.to_s unless blk
  yield(dir) if blk
ensure
  dir_levels.pop if blk
end
clear() click to toggle source
# File lib/fakefs/file_system.rb, line 14
def clear
  @dir_levels = nil
  @fs = nil
end
clone(path, target = nil) click to toggle source

copies directories and files from the real filesystem into our fake one

# File lib/fakefs/file_system.rb, line 55
def clone(path, target = nil)
  path    = RealFile.expand_path(path)
  pattern = File.join(path, '**', '*')
  files   = if RealFile.file?(path)
              [path]
            else
              [path] + RealDir.glob(pattern, RealFile::FNM_DOTMATCH)
            end

  files.each do |f|
    target_path = target ? f.gsub(path, target) : f

    if RealFile.symlink?(f)
      FileUtils.ln_s(RealFile.readlink(f), f)
    elsif RealFile.file?(f)
      FileUtils.mkdir_p(File.dirname(f))
      File.open(target_path, File::WRITE_ONLY) do |g|
        g.print RealFile.read(f)
      end
    elsif RealFile.directory?(f)
      FileUtils.mkdir_p(target_path)
    end
  end
end
current_dir() click to toggle source
# File lib/fakefs/file_system.rb, line 114
def current_dir
  find('.')
end
delete(path) click to toggle source
# File lib/fakefs/file_system.rb, line 80
def delete(path)
  return unless (node = FileSystem.find(path))
  node.delete
  true
end
dir_levels() click to toggle source
# File lib/fakefs/file_system.rb, line 6
def dir_levels
  @dir_levels ||= ['/']
end
files() click to toggle source
# File lib/fakefs/file_system.rb, line 19
def files
  fs.entries
end
find(path, find_flags = 0, gave_char_class = false) click to toggle source
# File lib/fakefs/file_system.rb, line 23
def find(path, find_flags = 0, gave_char_class = false)
  parts = path_parts(normalize_path(path))
  return fs if parts.empty? # '/'

  entries = Globber.expand(path).flat_map do |pattern|
    parts = path_parts(normalize_path(pattern))
    find_recurser(fs, parts, find_flags, gave_char_class).flatten
  end

  case entries.length
  when 0 then nil
  when 1 then entries.first
  else entries
  end
end
fs() click to toggle source
# File lib/fakefs/file_system.rb, line 10
def fs
  @fs ||= FakeDir.new('/')
end
normalize_path(path) click to toggle source
# File lib/fakefs/file_system.rb, line 103
def normalize_path(path)
  if Pathname.new(path).absolute?
    RealFile.expand_path(path)
  else
    parts = dir_levels + [path]
    RealFile.expand_path(parts.reduce do |base, part|
                           Pathname(base) + part
                         end.to_s)
  end
end
path_parts(path) click to toggle source
# File lib/fakefs/file_system.rb, line 99
def path_parts(path)
  Globber.path_components(path)
end

Private Instance Methods

assert_dir(dir) click to toggle source
# File lib/fakefs/file_system.rb, line 160
def assert_dir(dir)
  raise Errno::EEXIST, dir.name unless dir.is_a?(FakeDir)
end
directories_under(dir) click to toggle source
# File lib/fakefs/file_system.rb, line 154
def directories_under(dir)
  children = dir.entries.select { |f| f.is_a? FakeDir }
  ([dir] + children + children.map { |c| directories_under(c) })
    .flatten.uniq
end
find_recurser(dir, parts, find_flags = 0, gave_char_class = false) click to toggle source
# File lib/fakefs/file_system.rb, line 120
def find_recurser(dir, parts, find_flags = 0, gave_char_class = false)
  return [] unless dir.respond_to? :[]
  pattern, *parts = parts
  matches =
    case pattern
    when '**'
      case parts
      when ['*']
        parts = [] # end recursion
        directories_under(dir).map do |d|
          d.entries.select do |f|
            (f.is_a?(FakeFile) || f.is_a?(FakeDir)) &&
              f.name.match(/\A(?!\.)/)
          end
        end.flatten.uniq
      when []
        parts = [] # end recursion
        dir.entries.flatten.uniq
      else
        directories_under(dir)
      end
    else
      Globber.expand(pattern).flat_map do |subpattern|
        dir.matches(Globber.regexp(subpattern, find_flags, gave_char_class))
      end
    end

  if parts.empty? # we're done recursing
    matches
  else
    matches.map { |entry| find_recurser(entry, parts, find_flags, gave_char_class) }
  end
end