21
21
from bzrlib.branch import Branch
22
from bzrlib.tests.blackbox import ExternalBase
22
from bzrlib.tests import TestCaseInTempDir
23
23
from bzrlib.trace import mutter
24
24
from bzrlib.config import (ensure_config_dir_exists, config_filename)
27
class TestAliases(ExternalBase):
27
class TestAliases(TestCaseInTempDir):
29
29
def test_aliases(self):
31
def bzr(args, **kwargs):
32
return self.run_bzr(args, **kwargs)[0]
31
def bzr(*args, **kwargs):
32
return self.run_bzr(*args, **kwargs)[0]
34
def bzr_catch_error(args, **kwargs):
35
return self.run_bzr(args, **kwargs)[1]
34
def bzr_catch_error(*args, **kwargs):
35
return self.run_bzr(*args, **kwargs)[1]
38
38
if os.path.isfile(config_filename()):
39
39
# Something is wrong in environment,
40
40
# we risk overwriting users config
41
41
self.assert_(config_filename() + "exists, abort")
43
43
ensure_config_dir_exists()
44
44
CONFIG=("[ALIASES]\n"
49
49
open(config_filename(),'wb').write(CONFIG)
54
tree = self.make_branch_and_tree('.')
55
self.build_tree_contents([('a', str1)])
57
tree.commit(message='1')
59
self.assertEquals(bzr('c a'), str1)
61
self.build_tree_contents([('a', str2)])
62
tree.commit(message='2')
64
self.assertEquals(bzr('c a'), str2)
65
self.assertEquals(bzr('c1 a'), str1)
66
self.assertEquals(bzr('c1 --revision 2 a'), str2)
56
open('a', 'wb').write(str1)
59
bzr('commit', '-m', '1')
61
self.assertEquals(bzr('c', 'a'), str1)
63
open('a', 'wb').write(str2)
64
bzr('commit', '-m', '2')
66
self.assertEquals(bzr('c', 'a'), str2)
67
self.assertEquals(bzr('c1', 'a'), str1)
68
self.assertEquals(bzr('c1', '--revision', '2', 'a'), str2)
68
70
# If --no-aliases isn't working, we will not get retcode=3
69
bzr('--no-aliases c a', retcode=3)
71
bzr('--no-aliases', 'c', 'a', retcode=3)
71
73
# If --no-aliases breaks all of bzr, we also get retcode=3
72
74
# So we need to catch the output as well
73
self.assertEquals(bzr_catch_error('--no-aliases c a',
75
self.assertEquals(bzr_catch_error('--no-aliases', 'c', 'a',
75
77
'bzr: ERROR: unknown command "c"\n')
77
bzr('c -r1 -r2', retcode=3)
78
bzr('c1 -r1 -r2', retcode=3)
79
bzr('c', '-r1', '-r2', retcode=3)
80
bzr('c1', '-r1', '-r2', retcode=3)
79
81
bzr('c2', retcode=3)
80
bzr('c2 -r1', retcode=3)
82
bzr('c2', '-r1', retcode=3)