summary refs log tree commit diff stats
path: root/test/tc_relative_symlink.py
blob: a202513d699adac86edcd83ef4d4bd1cc575068c (plain) (blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
# Copyright (C) 2009, 2010  Roman Zimbelmann <romanz@lavabit.com>
#
# This program is free software: you can redistribute it and/or modify
# it under the terms of the GNU General Public License as published by
# the Free Software Foundation, either version 3 of the License, or
# (at your option) any later version.
#
# This program is distributed in the hope that it will be useful,
# but WITHOUT ANY WARRANTY; without even the implied warranty of
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
# GNU General Public License for more details.
#
# You should have received a copy of the GNU General Public License
# along with this program.  If not, see <http://www.gnu.org/licenses/>.

import os.path
import sys
rangerpath = os.path.join(os.path.dirname(__file__), '..')
if sys.path[1] != rangerpath:
	sys.path[1:1] = [rangerpath]

import unittest
from ranger.ext.relative_symlink import *
rel = get_relative_source_file

class Test(unittest.TestCase):
	def test_foo(self):
		self.assertEqual('../foo', rel('/foo', '/x/bar'))
		self.assertEqual('../../foo', rel('/foo', '/x/y/bar'))
		self.assertEqual('../../a/b/foo', rel('/a/b/foo', '/x/y/bar'))
		self.assertEqual('../../x/b/foo', rel('/x/b/foo', '/x/y/bar',
			common_base='/'))
		self.assertEqual('../b/foo', rel('/x/b/foo', '/x/y/bar'))
		self.assertEqual('../b/foo', rel('/x/b/foo', '/x/y/bar'))

	def test_get_common_base(self):
		self.assertEqual('/', get_common_base('', ''))
		self.assertEqual('/', get_common_base('', '/'))
		self.assertEqual('/', get_common_base('/', ''))
		self.assertEqual('/', get_common_base('/', '/'))
		self.assertEqual('/', get_common_base('/bla/bar/x', '/foo/bar/a'))
		self.assertEqual('/foo/bar/', get_common_base('/foo/bar/x', '/foo/bar/a'))
		self.assertEqual('/foo/', get_common_base('/foo/bar/x', '/foo/baz/a'))
		self.assertEqual('/foo/', get_common_base('/foo/bar/x', '/foo/baz/a'))
		self.assertEqual('/', get_common_base('//foo/bar/x', '/foo/baz/a'))

if __name__ == '__main__': unittest.main()
,'#'); if(number_sign) *number_sign = '\0'; /* * On Unix, first try to open it as a completely referenced file, * then via the path alone. * * On VMS, only try the path. */ #ifndef VMS colon = strchr(newfile,':'); StrAllocCopy(filename, colon+1); HTUnEscape(filename); if((fp = fopen(filename,"r")) == NULL) { FREE(filename); #endif /* !VMS */ filename = HTParse(newfile,"",PARSE_PATH+PARSE_PUNCTUATION); HTUnEscape(filename); #ifdef VMS if ((fp = fopen(HTVMS_name("",filename),"r")) == NULL) { #else if ((fp = fopen(filename,"r")) == NULL) { #endif /* VMS */ HTAlert(COULD_NOT_ACCESS_FILE); FREE(filename); goto failure; } #ifndef VMS } #endif /* !VMS */ fclose(fp); #if defined(VMS) || defined(CANT_EDIT_UNWRITABLE_FILES) /* * Don't allow editing if user lacks append access. */ #ifdef VMS if ((fp = fopen(HTVMS_name("",filename),"a")) == NULL) { #else if ((fp = fopen(filename,"a")) == NULL) { #endif /* VMS */ _statusline(NOAUTH_TO_EDIT_FILE); sleep(MessageSecs); goto failure; } fclose(fp); #endif /* VMS || CANT_EDIT_UNWRITABLE_FILES */ #ifdef VMS sprintf(command,"%s %s",editor, HTVMS_name("",filename)); #else if (strstr(editor,"emacs") || strstr(editor,"vi") || strstr(editor, "pico") || strstr(editor,"jove") || strstr(editor, "jed")) sprintf(command,"%s +%d \"%s\"",editor, lineno+links[cur].ly, filename); else sprintf(command,"%s \"%s\"",editor, filename); #endif /* VMS */ if (TRACE) { fprintf(stderr, "LYEdit: %s\n",command); sleep(MessageSecs); } FREE(filename); stop_curses(); system(command); start_curses(); if(number_sign) *number_sign = '#'; return TRUE; failure: if(number_sign) *number_sign = '#'; return FALSE; }