1
0
Fork 0
mirror of https://github.com/ruby/ruby.git synced 2022-11-09 12:17:21 -05:00
ruby--ruby/spec/rubyspec/library/pathname/relative_path_from_spec.rb
eregon 95e8c48dd3 Add in-tree mspec and ruby/spec
* For easier modifications of ruby/spec by MRI developers.
* .gitignore: track changes under spec.
* spec/mspec, spec/rubyspec: add in-tree mspec and ruby/spec.
  These files can therefore be updated like any other file in MRI.
  Instructions are provided in spec/README.
  [Feature #13156] [ruby-core:79246]

git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/trunk@58595 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
2017-05-07 12:04:49 +00:00

51 lines
1.7 KiB
Ruby

require File.expand_path('../../../spec_helper', __FILE__)
require 'pathname'
describe "Pathname#relative_path_from" do
def relative_path_str(dest, base)
Pathname.new(dest).relative_path_from(Pathname.new(base)).to_s
end
it "raises an error when the two paths do not share a common prefix" do
lambda { relative_path_str('/usr', 'foo') }.should raise_error(ArgumentError)
end
it "raises an error when the base directory has .." do
lambda { relative_path_str('a', '..') }.should raise_error(ArgumentError)
end
it "retuns a path relative from root" do
relative_path_str('/usr', '/').should == 'usr'
end
it 'returns 1 level up when both paths are relative' do
relative_path_str('a', 'b').should == '../a'
relative_path_str('a', 'b/').should == '../a'
end
it 'returns a relative path when both are absolute' do
relative_path_str('/a', '/b').should == '../a'
end
it "returns a path relative to the current directory" do
relative_path_str('/usr/bin/ls', '/usr').should == 'bin/ls'
end
it 'returns a . when base and dest are the same' do
relative_path_str('/usr', '/usr').should == '.'
end
it 'returns the same directory with a non clean base that matches the current dir' do
relative_path_str('/usr', '/stuff/..').should == 'usr'
end
it 'returns a relative path with a non clean base that matches a different dir' do
relative_path_str('/usr', '/stuff/../foo').should == '../usr'
end
it 'returns current and pattern when only those patterns are used' do
relative_path_str('.', '.').should == '.'
relative_path_str('..', '..').should == '.'
relative_path_str('..', '.').should == '..'
end
end