mirror of
https://github.com/ruby/ruby.git
synced 2022-11-09 12:17:21 -05:00
Pathname#relative_path_from compatible with mock.
[Fix GH-2049] git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/trunk@66416 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
This commit is contained in:
parent
13fd78c2e1
commit
4cf828632f
2 changed files with 20 additions and 2 deletions
|
@ -503,9 +503,13 @@ class Pathname
|
|||
# ArgumentError is raised when it cannot find a relative path.
|
||||
#
|
||||
def relative_path_from(base_directory)
|
||||
base_directory = Pathname.new(base_directory) unless Pathname === base_directory
|
||||
dest_directory = self.cleanpath.to_s
|
||||
base_directory = base_directory.cleanpath.to_s
|
||||
base_directory =
|
||||
if base_directory.respond_to? :cleanpath
|
||||
base_directory
|
||||
else
|
||||
Pathname.new(base_directory)
|
||||
end.cleanpath.to_s
|
||||
dest_prefix = dest_directory
|
||||
dest_names = []
|
||||
while r = chop_basename(dest_prefix)
|
||||
|
|
|
@ -1429,4 +1429,18 @@ class TestPathname < Test::Unit::TestCase
|
|||
assert_instance_of(Pathname, foo.relative_path_from(bar))
|
||||
end;
|
||||
end
|
||||
|
||||
def test_relative_path_from_mock
|
||||
assert_equal(
|
||||
Pathname.new("../bar"),
|
||||
Pathname.new("/foo/bar").relative_path_from(Pathname.new("/foo/baz")))
|
||||
assert_equal(
|
||||
Pathname.new("../bar"),
|
||||
Pathname.new("/foo/bar").relative_path_from("/foo/baz"))
|
||||
obj = Object.new
|
||||
def obj.cleanpath() Pathname.new("/foo/baz") end
|
||||
assert_equal(
|
||||
Pathname.new("../bar"),
|
||||
Pathname.new("/foo/bar").relative_path_from(obj))
|
||||
end
|
||||
end
|
||||
|
|
Loading…
Reference in a new issue