mirror of
https://github.com/tahoe-lafs/tahoe-lafs.git
synced 2024-12-24 07:06:41 +00:00
scripts/common: fix alias handling on windows again, emit slightly nicer error message in response to an unknown alias
This commit is contained in:
parent
fdb0200eca
commit
7f8708cb7c
@ -124,6 +124,9 @@ def platform_uses_lettercolon_drivename():
|
|||||||
return True
|
return True
|
||||||
return False
|
return False
|
||||||
|
|
||||||
|
class UnknownAliasError(Exception):
|
||||||
|
pass
|
||||||
|
|
||||||
def get_alias(aliases, path, default):
|
def get_alias(aliases, path, default):
|
||||||
# transform "work:path/filename" into (aliases["work"], "path/filename").
|
# transform "work:path/filename" into (aliases["work"], "path/filename").
|
||||||
# If default=None, then an empty alias is indicated by returning
|
# If default=None, then an empty alias is indicated by returning
|
||||||
@ -143,7 +146,7 @@ def get_alias(aliases, path, default):
|
|||||||
if default == None:
|
if default == None:
|
||||||
return DefaultAliasMarker, path
|
return DefaultAliasMarker, path
|
||||||
return aliases[default], path
|
return aliases[default], path
|
||||||
if colon == 1 and platform_uses_lettercolon_drivename():
|
if colon == 1 and default == None and platform_uses_lettercolon_drivename():
|
||||||
# treat C:\why\must\windows\be\so\weird as a local path, not a tahoe
|
# treat C:\why\must\windows\be\so\weird as a local path, not a tahoe
|
||||||
# file in the "C:" alias
|
# file in the "C:" alias
|
||||||
return DefaultAliasMarker, path
|
return DefaultAliasMarker, path
|
||||||
@ -154,6 +157,8 @@ def get_alias(aliases, path, default):
|
|||||||
if default == None:
|
if default == None:
|
||||||
return DefaultAliasMarker, path
|
return DefaultAliasMarker, path
|
||||||
return aliases[default], path
|
return aliases[default], path
|
||||||
|
if alias not in aliases:
|
||||||
|
raise UnknownAliasError("Unknown alias '%s', please create it with 'tahoe add-alias' or 'tahoe create-alias'." % alias)
|
||||||
return aliases[alias], path[colon+1:]
|
return aliases[alias], path[colon+1:]
|
||||||
|
|
||||||
def escape_path(path):
|
def escape_path(path):
|
||||||
|
@ -281,6 +281,7 @@ class CLI(unittest.TestCase):
|
|||||||
"c": "CA"}
|
"c": "CA"}
|
||||||
def ga1(path):
|
def ga1(path):
|
||||||
return get_alias(aliases, path, "tahoe")
|
return get_alias(aliases, path, "tahoe")
|
||||||
|
uses_lettercolon = common.platform_uses_lettercolon_drivename()
|
||||||
self.failUnlessEqual(ga1("bare"), ("TA", "bare"))
|
self.failUnlessEqual(ga1("bare"), ("TA", "bare"))
|
||||||
self.failUnlessEqual(ga1("baredir/file"), ("TA", "baredir/file"))
|
self.failUnlessEqual(ga1("baredir/file"), ("TA", "baredir/file"))
|
||||||
self.failUnlessEqual(ga1("baredir/file:7"), ("TA", "baredir/file:7"))
|
self.failUnlessEqual(ga1("baredir/file:7"), ("TA", "baredir/file:7"))
|
||||||
@ -290,6 +291,8 @@ class CLI(unittest.TestCase):
|
|||||||
self.failUnlessEqual(ga1("work:"), ("WA", ""))
|
self.failUnlessEqual(ga1("work:"), ("WA", ""))
|
||||||
self.failUnlessEqual(ga1("work:file"), ("WA", "file"))
|
self.failUnlessEqual(ga1("work:file"), ("WA", "file"))
|
||||||
self.failUnlessEqual(ga1("work:dir/file"), ("WA", "dir/file"))
|
self.failUnlessEqual(ga1("work:dir/file"), ("WA", "dir/file"))
|
||||||
|
# default != None means we really expect a tahoe path, regardless of
|
||||||
|
# whether we're on windows or not. This is what 'tahoe get' uses.
|
||||||
self.failUnlessEqual(ga1("c:"), ("CA", ""))
|
self.failUnlessEqual(ga1("c:"), ("CA", ""))
|
||||||
self.failUnlessEqual(ga1("c:file"), ("CA", "file"))
|
self.failUnlessEqual(ga1("c:file"), ("CA", "file"))
|
||||||
self.failUnlessEqual(ga1("c:dir/file"), ("CA", "dir/file"))
|
self.failUnlessEqual(ga1("c:dir/file"), ("CA", "dir/file"))
|
||||||
@ -297,6 +300,10 @@ class CLI(unittest.TestCase):
|
|||||||
self.failUnlessEqual(ga1("URI:stuff:./file"), ("URI:stuff", "file"))
|
self.failUnlessEqual(ga1("URI:stuff:./file"), ("URI:stuff", "file"))
|
||||||
self.failUnlessEqual(ga1("URI:stuff:./dir/file"),
|
self.failUnlessEqual(ga1("URI:stuff:./dir/file"),
|
||||||
("URI:stuff", "dir/file"))
|
("URI:stuff", "dir/file"))
|
||||||
|
self.failUnlessRaises(common.UnknownAliasError, ga1, "missing:")
|
||||||
|
self.failUnlessRaises(common.UnknownAliasError, ga1, "missing:dir")
|
||||||
|
self.failUnlessRaises(common.UnknownAliasError, ga1, "missing:dir/file")
|
||||||
|
|
||||||
def ga2(path):
|
def ga2(path):
|
||||||
return get_alias(aliases, path, None)
|
return get_alias(aliases, path, None)
|
||||||
self.failUnlessEqual(ga2("bare"), (DefaultAliasMarker, "bare"))
|
self.failUnlessEqual(ga2("bare"), (DefaultAliasMarker, "bare"))
|
||||||
@ -309,15 +316,26 @@ class CLI(unittest.TestCase):
|
|||||||
self.failUnlessEqual(ga2("tahoe:"), ("TA", ""))
|
self.failUnlessEqual(ga2("tahoe:"), ("TA", ""))
|
||||||
self.failUnlessEqual(ga2("tahoe:file"), ("TA", "file"))
|
self.failUnlessEqual(ga2("tahoe:file"), ("TA", "file"))
|
||||||
self.failUnlessEqual(ga2("tahoe:dir/file"), ("TA", "dir/file"))
|
self.failUnlessEqual(ga2("tahoe:dir/file"), ("TA", "dir/file"))
|
||||||
self.failUnlessEqual(ga1("c:"), ("CA", ""))
|
# on windows, we really want c:foo to indicate a local file.
|
||||||
self.failUnlessEqual(ga1("c:file"), ("CA", "file"))
|
# default==None is what 'tahoe cp' uses.
|
||||||
self.failUnlessEqual(ga1("c:dir/file"), ("CA", "dir/file"))
|
if uses_lettercolon:
|
||||||
|
self.failUnlessEqual(ga2("c:"), (DefaultAliasMarker, "c:"))
|
||||||
|
self.failUnlessEqual(ga2("c:file"), (DefaultAliasMarker, "c:file"))
|
||||||
|
self.failUnlessEqual(ga2("c:dir/file"),
|
||||||
|
(DefaultAliasMarker, "c:dir/file"))
|
||||||
|
else:
|
||||||
|
self.failUnlessEqual(ga2("c:"), ("CA", ""))
|
||||||
|
self.failUnlessEqual(ga2("c:file"), ("CA", "file"))
|
||||||
|
self.failUnlessEqual(ga2("c:dir/file"), ("CA", "dir/file"))
|
||||||
self.failUnlessEqual(ga2("work:"), ("WA", ""))
|
self.failUnlessEqual(ga2("work:"), ("WA", ""))
|
||||||
self.failUnlessEqual(ga2("work:file"), ("WA", "file"))
|
self.failUnlessEqual(ga2("work:file"), ("WA", "file"))
|
||||||
self.failUnlessEqual(ga2("work:dir/file"), ("WA", "dir/file"))
|
self.failUnlessEqual(ga2("work:dir/file"), ("WA", "dir/file"))
|
||||||
self.failUnlessEqual(ga2("URI:stuff"), ("URI:stuff", ""))
|
self.failUnlessEqual(ga2("URI:stuff"), ("URI:stuff", ""))
|
||||||
self.failUnlessEqual(ga2("URI:stuff:./file"), ("URI:stuff", "file"))
|
self.failUnlessEqual(ga2("URI:stuff:./file"), ("URI:stuff", "file"))
|
||||||
self.failUnlessEqual(ga2("URI:stuff:./dir/file"), ("URI:stuff", "dir/file"))
|
self.failUnlessEqual(ga2("URI:stuff:./dir/file"), ("URI:stuff", "dir/file"))
|
||||||
|
self.failUnlessRaises(common.UnknownAliasError, ga2, "missing:")
|
||||||
|
self.failUnlessRaises(common.UnknownAliasError, ga2, "missing:dir")
|
||||||
|
self.failUnlessRaises(common.UnknownAliasError, ga2, "missing:dir/file")
|
||||||
|
|
||||||
def ga3(path):
|
def ga3(path):
|
||||||
old = common.pretend_platform_uses_lettercolon
|
old = common.pretend_platform_uses_lettercolon
|
||||||
@ -347,6 +365,9 @@ class CLI(unittest.TestCase):
|
|||||||
self.failUnlessEqual(ga3("URI:stuff"), ("URI:stuff", ""))
|
self.failUnlessEqual(ga3("URI:stuff"), ("URI:stuff", ""))
|
||||||
self.failUnlessEqual(ga3("URI:stuff:./file"), ("URI:stuff", "file"))
|
self.failUnlessEqual(ga3("URI:stuff:./file"), ("URI:stuff", "file"))
|
||||||
self.failUnlessEqual(ga3("URI:stuff:./dir/file"), ("URI:stuff", "dir/file"))
|
self.failUnlessEqual(ga3("URI:stuff:./dir/file"), ("URI:stuff", "dir/file"))
|
||||||
|
self.failUnlessRaises(common.UnknownAliasError, ga3, "missing:")
|
||||||
|
self.failUnlessRaises(common.UnknownAliasError, ga3, "missing:dir")
|
||||||
|
self.failUnlessRaises(common.UnknownAliasError, ga3, "missing:dir/file")
|
||||||
|
|
||||||
|
|
||||||
class Help(unittest.TestCase):
|
class Help(unittest.TestCase):
|
||||||
|
Loading…
Reference in New Issue
Block a user