/brz/remove-bazaar

To get this branch, use:
bzr branch http://gegoxaren.bato24.eu/bzr/brz/remove-bazaar
1185.16.32 by Martin Pool
- add a basic annotate built-in command
1
# Copyright (C) 2005 by Canonical Ltd
2
# -*- coding: utf-8 -*-
3
4
# This program is free software; you can redistribute it and/or modify
5
# it under the terms of the GNU General Public License as published by
6
# the Free Software Foundation; either version 2 of the License, or
7
# (at your option) any later version.
8
9
# This program is distributed in the hope that it will be useful,
10
# but WITHOUT ANY WARRANTY; without even the implied warranty of
11
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
12
# GNU General Public License for more details.
13
14
# You should have received a copy of the GNU General Public License
15
# along with this program; if not, write to the Free Software
16
# Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307  USA
17
18
19
"""Black-box tests for bzr.
20
21
These check that it behaves properly when it's invoked through the regular
22
command-line interface. This doesn't actually run a new interpreter but 
23
rather starts again from the run_bzr function.
24
"""
25
26
27
from cStringIO import StringIO
28
import os
29
import shutil
30
import sys
31
import os
32
33
from bzrlib.branch import Branch
34
from bzrlib.errors import BzrCommandError
35
from bzrlib.osutils import has_symlinks
1534.4.26 by Robert Collins
Move working tree initialisation out from Branch.initialize, deprecated Branch.initialize to Branch.create.
36
from bzrlib.tests import TestCaseWithTransport
1185.16.32 by Martin Pool
- add a basic annotate built-in command
37
from bzrlib.annotate import annotate_file
38
39
1534.4.26 by Robert Collins
Move working tree initialisation out from Branch.initialize, deprecated Branch.initialize to Branch.create.
40
class TestAnnotate(TestCaseWithTransport):
41
1185.16.53 by Martin Pool
- annotate improvements from Goffreddo, with extra bug fixes and tests
42
    def setUp(self):
43
        super(TestAnnotate, self).setUp()
1534.4.26 by Robert Collins
Move working tree initialisation out from Branch.initialize, deprecated Branch.initialize to Branch.create.
44
        wt = self.make_branch_and_tree('.')
45
        b = wt.branch
1185.33.31 by Martin Pool
Make annotate cope better with revisions committed without a valid
46
        self.build_tree_contents([('hello.txt', 'my helicopter\n'),
47
                                  ('nomail.txt', 'nomail\n')])
1534.4.26 by Robert Collins
Move working tree initialisation out from Branch.initialize, deprecated Branch.initialize to Branch.create.
48
        wt.add(['hello.txt'])
1558.14.6 by Aaron Bentley
Added annotate test
49
        wt.commit('add hello', committer='test@user')
1534.4.26 by Robert Collins
Move working tree initialisation out from Branch.initialize, deprecated Branch.initialize to Branch.create.
50
        wt.add(['nomail.txt'])
51
        wt.commit('add nomail', committer='no mail')
1558.14.6 by Aaron Bentley
Added annotate test
52
        file('hello.txt', 'ab').write('your helicopter')
53
        wt.commit('mod hello', committer='user@test')
1185.16.53 by Martin Pool
- annotate improvements from Goffreddo, with extra bug fixes and tests
54
1185.16.32 by Martin Pool
- add a basic annotate built-in command
55
    def test_help_annotate(self):
56
        """Annotate command exists"""
57
        out, err = self.run_bzr_captured(['--no-plugins', 'annotate', '--help'])
1185.16.53 by Martin Pool
- annotate improvements from Goffreddo, with extra bug fixes and tests
58
59
    def test_annotate_cmd(self):
60
        out, err = self.run_bzr_captured(['annotate', 'hello.txt'])
61
        self.assertEquals(err, '')
62
        self.assertEqualDiff(out, '''\
63
    1 test@us | my helicopter
1558.14.6 by Aaron Bentley
Added annotate test
64
    3 user@te | your helicopter
1185.16.53 by Martin Pool
- annotate improvements from Goffreddo, with extra bug fixes and tests
65
''')
1185.33.31 by Martin Pool
Make annotate cope better with revisions committed without a valid
66
67
    def test_no_mail(self):
68
        out, err = self.run_bzr_captured(['annotate', 'nomail.txt'])
69
        self.assertEquals(err, '')
70
        self.assertEqualDiff(out, '''\
71
    2 no mail | nomail
72
''')
1694.2.6 by Martin Pool
[merge] bzr.dev
73
74
    def test_annotate_cmd_revision(self):
75
        out, err = self.run_bzr_captured(['annotate', 'hello.txt', '-r 1'])
76
        self.assertEquals(err, '')
77
        self.assertEqualDiff(out, '''\
78
    1 test@us | my helicopter
79
''')
80
1558.14.6 by Aaron Bentley
Added annotate test
81
    def test_annotate_cmd_revision3(self):
82
        out, err = self.run_bzr_captured(['annotate', 'hello.txt', '-r 3'])
83
        self.assertEquals(err, '')
84
        self.assertEqualDiff(out, '''\
85
    1 test@us | my helicopter
86
    3 user@te | your helicopter
87
''')
88
1694.2.6 by Martin Pool
[merge] bzr.dev
89
    def test_annotate_cmd_unknown_revision(self):
90
        out, err = self.run_bzr_captured(['annotate', 'hello.txt', '-r 10'],
91
                                         retcode=3)
92
        self.assertEquals(out, '')
93
        self.assertContainsRe(err, 'has no revision 10')
94
95
    def test_annotate_cmd_two_revisions(self):
96
        out, err = self.run_bzr_captured(['annotate', 'hello.txt', '-r 1..2'],
97
                                         retcode=3)
98
        self.assertEquals(out, '')
99
        self.assertEquals(err, 'bzr: ERROR: bzr annotate --revision takes'
100
                               ' exactly 1 argument\n')