45
38
self.build_tree_contents([('hello.txt', 'my helicopter\n'),
46
39
('nomail.txt', 'nomail\n')])
47
40
wt.add(['hello.txt'])
48
wt.commit('add hello', committer='test@user')
41
self.revision_id_1 = wt.commit('add hello',
42
committer='test@user',
43
timestamp=1165960000.00, timezone=0)
49
44
wt.add(['nomail.txt'])
50
wt.commit('add nomail', committer='no mail')
51
file('hello.txt', 'ab').write('your helicopter')
52
wt.commit('mod hello', committer='user@test')
45
self.revision_id_2 = wt.commit('add nomail',
47
timestamp=1165970000.00, timezone=0)
48
self.build_tree_contents([('hello.txt', 'my helicopter\n'
49
'your helicopter\n')])
50
self.revision_id_3 = wt.commit('mod hello',
51
committer='user@test',
52
timestamp=1166040000.00, timezone=0)
53
self.build_tree_contents([('hello.txt', 'my helicopter\n'
58
self.revision_id_4 = wt.commit('mod hello',
59
committer='user@test',
60
timestamp=1166050000.00, timezone=0)
54
62
def test_help_annotate(self):
55
63
"""Annotate command exists"""
56
out, err = self.run_bzr_captured(['--no-plugins', 'annotate', '--help'])
64
out, err = self.run_bzr('--no-plugins', 'annotate', '--help')
58
66
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
3 user@te | your helicopter
67
out, err = self.run_bzr('annotate', 'hello.txt')
68
self.assertEqual('', err)
69
self.assertEqualDiff('''\
70
1 test@us | my helicopter
71
3 user@te | your helicopter
76
def test_annotate_cmd_full(self):
77
out, err = self.run_bzr('annotate', 'hello.txt', '--all')
78
self.assertEqual('', err)
79
self.assertEqualDiff('''\
80
1 test@us | my helicopter
81
3 user@te | your helicopter
83
4 user@te | our helicopters
86
def test_annotate_cmd_long(self):
87
out, err = self.run_bzr('annotate', 'hello.txt', '--long')
88
self.assertEqual('', err)
89
self.assertEqualDiff('''\
90
1 test@user 20061212 | my helicopter
91
3 user@test 20061213 | your helicopter
92
4 user@test 20061213 | all of
96
def test_annotate_cmd_show_ids(self):
97
out, err = self.run_bzr('annotate', 'hello.txt', '--show-ids')
98
max_len = max([len(self.revision_id_1),
99
len(self.revision_id_3),
100
len(self.revision_id_4)])
101
self.assertEqual('', err)
102
self.assertEqualDiff('''\
104
%*s | your helicopter
106
%*s | our helicopters
107
''' % (max_len, self.revision_id_1,
108
max_len, self.revision_id_3,
109
max_len, self.revision_id_4,
66
114
def test_no_mail(self):
67
out, err = self.run_bzr_captured(['annotate', 'nomail.txt'])
68
self.assertEquals(err, '')
69
self.assertEqualDiff(out, '''\
115
out, err = self.run_bzr('annotate', 'nomail.txt')
116
self.assertEqual('', err)
117
self.assertEqualDiff('''\
73
121
def test_annotate_cmd_revision(self):
74
out, err = self.run_bzr_captured(['annotate', 'hello.txt', '-r 1'])
75
self.assertEquals(err, '')
76
self.assertEqualDiff(out, '''\
77
1 test@us | my helicopter
122
out, err = self.run_bzr('annotate', 'hello.txt', '-r1')
123
self.assertEqual('', err)
124
self.assertEqualDiff('''\
125
1 test@us | my helicopter
80
128
def test_annotate_cmd_revision3(self):
81
out, err = self.run_bzr_captured(['annotate', 'hello.txt', '-r 3'])
82
self.assertEquals(err, '')
83
self.assertEqualDiff(out, '''\
84
1 test@us | my helicopter
85
3 user@te | your helicopter
129
out, err = self.run_bzr('annotate', 'hello.txt', '-r3')
130
self.assertEqual('', err)
131
self.assertEqualDiff('''\
132
1 test@us | my helicopter
133
3 user@te | your helicopter
88
136
def test_annotate_cmd_unknown_revision(self):
89
out, err = self.run_bzr_captured(['annotate', 'hello.txt', '-r 10'],
91
self.assertEquals(out, '')
92
self.assertContainsRe(err, 'has no revision 10')
137
out, err = self.run_bzr('annotate', 'hello.txt', '-r', '10',
139
self.assertEqual('', out)
140
self.assertContainsRe(err, 'Requested revision: \'10\' does not exist')
94
142
def test_annotate_cmd_two_revisions(self):
95
out, err = self.run_bzr_captured(['annotate', 'hello.txt', '-r 1..2'],
97
self.assertEquals(out, '')
98
self.assertEquals(err, 'bzr: ERROR: bzr annotate --revision takes'
99
' exactly 1 argument\n')
143
out, err = self.run_bzr('annotate', 'hello.txt', '-r1..2',
145
self.assertEqual('', out)
146
self.assertEqual('bzr: ERROR: bzr annotate --revision takes'
147
' exactly 1 argument\n',
150
def test_annotate_empty_file(self):
151
tree = self.make_branch_and_tree('tree')
152
self.build_tree_contents([('tree/empty', '')])
154
tree.commit('add empty file')
157
out, err = self.run_bzr('annotate', 'empty')
158
self.assertEqual('', out)