fix random cloning bugs

This commit is contained in:
Chris Wanstrath 2009-07-19 15:23:42 -07:00
parent eb634265e6
commit a7f20095f0
2 changed files with 31 additions and 9 deletions

View File

@ -38,10 +38,10 @@ module FakeFS
end end
if dst_file and File.directory?(dst_file) if dst_file and File.directory?(dst_file)
FileSystem.add(File.join(dest, src), src_file.entry.clone(dest)) FileSystem.add(File.join(dest, src), src_file.entry.clone(dst_file))
else else
FileSystem.delete(dest) FileSystem.delete(dest)
FileSystem.add(dest, src_file.entry.clone(dest)) FileSystem.add(dest, src_file.entry.clone)
end end
end end
@ -64,18 +64,18 @@ module FakeFS
# about and cleaned up. # about and cleaned up.
if new_dir if new_dir
if src[-2..-1] == '/.' if src[-2..-1] == '/.'
dir.values.each{|f| new_dir[f.name] = f } dir.values.each{|f| new_dir[f.name] = f.clone(new_dir) }
else else
new_dir[dir.name] = dir.entry.clone(new_dir) new_dir[dir.name] = dir.entry.clone(new_dir)
end end
else else
FileSystem.add(dest, dir.entry.clone(dest)) FileSystem.add(dest, dir.entry.clone)
end end
end end
def mv(src, dest) def mv(src, dest)
if target = FileSystem.find(src) if target = FileSystem.find(src)
FileSystem.add(dest, target.entry.clone(dest)) FileSystem.add(dest, target.entry.clone)
FileSystem.delete(src) FileSystem.delete(src)
else else
raise Errno::ENOENT, src raise Errno::ENOENT, src
@ -353,15 +353,16 @@ module FakeFS
class MockFile class MockFile
attr_accessor :name, :parent, :content attr_accessor :name, :parent, :content
def initialize(name = nil, parent = nil) def initialize(name = nil, parent = nil)
@name = name @name = name
@parent = parent @parent = parent
@content = '' @content = ''
end end
def clone(parent) def clone(parent = nil)
clone = super() clone = super()
clone.parent = parent clone.parent = parent if parent
clone clone
end end
@ -369,6 +370,10 @@ module FakeFS
self self
end end
def inspect
"(MockFile name:#{name.inspect} parent:#{parent.to_s.inspect} size:#{content.size})"
end
def to_s def to_s
File.join(parent.to_s, name) File.join(parent.to_s, name)
end end
@ -386,11 +391,16 @@ module FakeFS
self self
end end
def clone(parent) def inspect
"(MockDir name:#{name.inspect} parent:#{parent.to_s.inspect} size:#{size})"
end
def clone(parent = nil)
clone = Marshal.load(Marshal.dump(self)) clone = Marshal.load(Marshal.dump(self))
clone.each do |key, value| clone.each do |key, value|
value.parent = parent value.parent = clone
end end
clone.parent = parent if parent
clone clone
end end

View File

@ -422,6 +422,18 @@ class FakeFSTest < Test::Unit::TestCase
assert_equal 'footext', File.open('symdir/subdir/foo'){|f| f.read } assert_equal 'footext', File.open('symdir/subdir/foo'){|f| f.read }
end end
def test_cp_r_sets_parent_correctly
FileUtils.mkdir_p '/path/foo'
File.open('/path/foo/bar', 'w'){|f| f.write 'foo' }
File.open('/path/foo/baz', 'w'){|f| f.write 'foo' }
FileUtils.cp_r '/path/foo', '/path/bar'
assert File.exists?('/path/bar/baz')
FileUtils.rm_rf '/path/bar/baz'
assert_equal %w( /path/bar/bar ), Dir['/path/bar/*']
end
def test_clone_clones_normal_files def test_clone_clones_normal_files
RealFile.open(here('foo'), 'w'){|f| f.write 'bar' } RealFile.open(here('foo'), 'w'){|f| f.write 'bar' }
assert !File.exists?(here('foo')) assert !File.exists?(here('foo'))