~bzr-pqm/bzr/bzr.dev

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'])
49
        wt.commit('add hello', 
1457.1.17 by Robert Collins
Branch.commit() has moved to WorkingTree.commit(). (Robert Collins)
50
                                committer='test@user')
1534.4.26 by Robert Collins
Move working tree initialisation out from Branch.initialize, deprecated Branch.initialize to Branch.create.
51
        wt.add(['nomail.txt'])
52
        wt.commit('add nomail', committer='no mail')
1185.16.53 by Martin Pool
- annotate improvements from Goffreddo, with extra bug fixes and tests
53
1185.16.32 by Martin Pool
- add a basic annotate built-in command
54
    def test_help_annotate(self):
55
        """Annotate command exists"""
56
        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
57
58
    def test_annotate_cmd(self):
59
        out, err = self.run_bzr_captured(['annotate', 'hello.txt'])
60
        self.assertEquals(err, '')
61
        self.assertEqualDiff(out, '''\
62
    1 test@us | my helicopter
63
''')
1185.33.31 by Martin Pool
Make annotate cope better with revisions committed without a valid
64
65
    def test_no_mail(self):
66
        out, err = self.run_bzr_captured(['annotate', 'nomail.txt'])
67
        self.assertEquals(err, '')
68
        self.assertEqualDiff(out, '''\
69
    2 no mail | nomail
70
''')