~bzr-pqm/bzr/bzr.dev

« back to all changes in this revision

Viewing changes to bzrlib/tests/blackbox/test_aliases.py

  • Committer: Robert Collins
  • Date: 2007-03-08 04:06:06 UTC
  • mfrom: (2323.1.1 integration)
  • mto: This revision was merged to the branch mainline in revision 2442.
  • Revision ID: robertc@robertcollins.net-20070308040606-84gsniv56huiyjt4
Merge bzr.dev.

Show diffs side-by-side

added added

removed removed

Lines of Context:
1
 
# Copyright (C) 2006, 2007, 2009, 2010 Canonical Ltd
 
1
# Copyright (C) 2005, 2006 Canonical Ltd
2
2
#
3
3
# This program is free software; you can redistribute it and/or modify
4
4
# it under the terms of the GNU General Public License as published by
12
12
#
13
13
# You should have received a copy of the GNU General Public License
14
14
# along with this program; if not, write to the Free Software
15
 
# Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
 
15
# Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307  USA
16
16
"""Black-box tests for bzr aliases.
17
17
"""
18
18
 
19
19
import os
20
20
 
21
 
from bzrlib import config
22
21
from bzrlib.branch import Branch
23
 
from bzrlib.tests import TestCaseWithTransport
 
22
from bzrlib.tests import TestCaseInTempDir
24
23
from bzrlib.trace import mutter
25
 
 
26
 
 
27
 
class TestAliases(TestCaseWithTransport):
 
24
from bzrlib.config import (ensure_config_dir_exists, config_filename)
 
25
 
 
26
 
 
27
class TestAliases(TestCaseInTempDir):
28
28
 
29
29
    def test_aliases(self):
30
30
 
31
 
        def bzr(args, **kwargs):
32
 
            return self.run_bzr(args, **kwargs)[0]
33
 
 
34
 
        def bzr_catch_error(args, **kwargs):
35
 
            return self.run_bzr(args, **kwargs)[1]
36
 
 
37
 
 
38
 
        conf = config.GlobalConfig.from_string('''[ALIASES]
39
 
c=cat
40
 
c1=cat -r 1
41
 
c2=cat -r 1 -r2
42
 
''', save=True)
 
31
        def bzr(*args, **kwargs):
 
32
            return self.run_bzr(*args, **kwargs)[0]
 
33
 
 
34
        def bzr_catch_error(*args, **kwargs):
 
35
            return self.run_bzr(*args, **kwargs)[1]
 
36
 
 
37
 
 
38
        if os.path.isfile(config_filename()):
 
39
            # Something is wrong in environment, 
 
40
            # we risk overwriting users config 
 
41
            self.assert_(config_filename() + "exists, abort")
 
42
        
 
43
        ensure_config_dir_exists()
 
44
        CONFIG=("[ALIASES]\n"
 
45
                "c=cat\n"
 
46
                "c1=cat -r 1\n"
 
47
                "c2=cat -r 1 -r2\n")
 
48
 
 
49
        open(config_filename(),'wb').write(CONFIG)
 
50
 
43
51
 
44
52
        str1 = 'foo\n'
45
53
        str2 = 'bar\n'
46
54
 
47
 
        tree = self.make_branch_and_tree('.')
48
 
        self.build_tree_contents([('a', str1)])
49
 
        tree.add('a')
50
 
        tree.commit(message='1')
51
 
 
52
 
        self.assertEquals(bzr('c a'), str1)
53
 
 
54
 
        self.build_tree_contents([('a', str2)])
55
 
        tree.commit(message='2')
56
 
 
57
 
        self.assertEquals(bzr('c a'), str2)
58
 
        self.assertEquals(bzr('c1 a'), str1)
59
 
        self.assertEquals(bzr('c1 --revision 2 a'), str2)
 
55
        bzr('init')
 
56
        open('a', 'wb').write(str1)
 
57
        bzr('add', 'a')
 
58
 
 
59
        bzr('commit', '-m', '1')
 
60
 
 
61
        self.assertEquals(bzr('c', 'a'), str1)
 
62
 
 
63
        open('a', 'wb').write(str2)
 
64
        bzr('commit', '-m', '2')
 
65
 
 
66
        self.assertEquals(bzr('c', 'a'), str2)
 
67
        self.assertEquals(bzr('c1', 'a'), str1)
 
68
        self.assertEquals(bzr('c1', '--revision', '2', 'a'), str2)
60
69
 
61
70
        # If --no-aliases isn't working, we will not get retcode=3
62
 
        bzr('--no-aliases c a', retcode=3)
 
71
        bzr('--no-aliases', 'c', 'a', retcode=3)
63
72
 
64
73
        # If --no-aliases breaks all of bzr, we also get retcode=3
65
74
        # So we need to catch the output as well
66
 
        self.assertEquals(bzr_catch_error('--no-aliases c a',
 
75
        self.assertEquals(bzr_catch_error('--no-aliases', 'c', 'a',
67
76
                                          retcode=None),
68
77
                          'bzr: ERROR: unknown command "c"\n')
69
78
 
70
 
        bzr('c -r1 -r2', retcode=3)
71
 
        bzr('c1 -r1 -r2', retcode=3)
 
79
        bzr('c', '-r1', '-r2', retcode=3)
 
80
        bzr('c1', '-r1', '-r2', retcode=3)
72
81
        bzr('c2', retcode=3)
73
 
        bzr('c2 -r1', retcode=3)
 
82
        bzr('c2', '-r1', retcode=3)