1
# Copyright (C) 2006, 2007, 2009, 2010, 2011, 2016 Canonical Ltd
3
# This program is free software; you can redistribute it and/or modify
4
# it under the terms of the GNU General Public License as published by
5
# the Free Software Foundation; either version 2 of the License, or
6
# (at your option) any later version.
8
# This program is distributed in the hope that it will be useful,
9
# but WITHOUT ANY WARRANTY; without even the implied warranty of
10
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
11
# GNU General Public License for more details.
13
# You should have received a copy of the GNU General Public License
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
17
"""Black-box tests for brz revert."""
22
from breezy.tests import TestCaseWithTransport
23
from breezy.trace import mutter
24
from breezy.workingtree import WorkingTree
27
class TestRevert(TestCaseWithTransport):
29
def _prepare_tree(self):
31
self.run_bzr('mkdir dir')
33
with open('dir/file', 'wb') as f:
35
self.run_bzr('add dir/file')
37
self.run_bzr('commit -m1')
40
with open('dir/file', 'wb') as f:
44
self.assertEqual('modified:\n dir/file\n', self.run_bzr('status')[0])
46
def _prepare_rename_mod_tree(self):
47
self.build_tree(['a/', 'a/b', 'a/c', 'a/d/', 'a/d/e', 'f/', 'f/g',
51
self.run_bzr('commit -m 1')
52
wt = WorkingTree.open('.')
53
wt.rename_one('a/b', 'f/b')
54
wt.rename_one('a/d/e', 'f/e')
55
wt.rename_one('a/d', 'f/d')
56
wt.rename_one('f/g', 'a/g')
57
wt.rename_one('f/h', 'h')
58
wt.rename_one('f', 'j')
60
def helper(self, param=''):
63
# revert to default revision for file in subdir does work
67
self.assertEqual('1\n', self.run_bzr('revno')[0])
68
self.run_bzr('revert %s file' % param)
69
self.assertEqual('spam', open('file', 'rb').read())
71
def test_revert_in_subdir(self):
74
def test_revert_to_revision_in_subdir(self):
75
# test case for bug #29424:
76
# revert to specific revision for file in subdir does not work
79
def test_revert_in_checkout(self):
83
self.run_bzr('checkout --lightweight . ../sprach')
84
self.run_bzr('commit -m more')
86
self.assertEqual('', self.run_bzr('status')[0])
87
self.run_bzr('revert')
88
self.assertEqual('', self.run_bzr('status')[0])
90
def test_revert_dirname(self):
91
"""Test that revert DIRECTORY does what's expected"""
92
self._prepare_rename_mod_tree()
93
self.run_bzr('revert a')
94
self.assertPathExists('a/b')
95
self.assertPathExists('a/d')
96
self.assertPathDoesNotExist('a/g')
98
"j is in the delta revert applies because j was renamed too",
99
self.assertPathExists, 'j')
100
self.assertPathExists('h')
101
self.run_bzr('revert f')
102
self.assertPathDoesNotExist('j')
103
self.assertPathDoesNotExist('h')
104
self.assertPathExists('a/d/e')
106
def test_revert_chatter(self):
107
self._prepare_rename_mod_tree()
108
chatter = self.run_bzr('revert')[1]
109
self.assertEqualDiff(
118
def test_revert(self):
121
with open('hello', 'wt') as f: f.write('foo')
122
self.run_bzr('add hello')
123
self.run_bzr('commit -m setup hello')
125
with open('goodbye', 'wt') as f: f.write('baz')
126
self.run_bzr('add goodbye')
127
self.run_bzr('commit -m setup goodbye')
129
with open('hello', 'wt') as f: f.write('bar')
130
with open('goodbye', 'wt') as f: f.write('qux')
131
self.run_bzr('revert hello')
132
self.check_file_contents('hello', b'foo')
133
self.check_file_contents('goodbye', b'qux')
134
self.run_bzr('revert')
135
self.check_file_contents('goodbye', b'baz')
137
os.mkdir('revertdir')
138
self.run_bzr('add revertdir')
139
self.run_bzr('commit -m f')
140
os.rmdir('revertdir')
141
self.run_bzr('revert')
143
if breezy.osutils.has_symlinks():
144
os.symlink('/unlikely/to/exist', 'symlink')
145
self.run_bzr('add symlink')
146
self.run_bzr('commit -m f')
148
self.run_bzr('revert')
149
self.assertPathExists('symlink')
151
os.symlink('a-different-path', 'symlink')
152
self.run_bzr('revert')
153
self.assertEqual('/unlikely/to/exist',
154
os.readlink('symlink'))
156
self.log("skipping revert symlink tests")
158
with open('hello', 'wt') as f: f.write('xyz')
159
self.run_bzr('commit -m xyz hello')
160
self.run_bzr('revert -r 1 hello')
161
self.check_file_contents('hello', b'foo')
162
self.run_bzr('revert hello')
163
self.check_file_contents('hello', b'xyz')
164
os.chdir('revertdir')
165
self.run_bzr('revert')
168
def test_revert_newly_added(self):
169
# this tests the UI reports reverting a newly added file
170
# correct (such files are not deleted)
171
tree = self.make_branch_and_tree('.')
172
self.build_tree(['file'])
174
out, err = self.run_bzr('revert')
175
self.assertEqual(b'', out)
176
self.assertEqual(b'- file\n', err)
178
def test_revert_removing_file(self):
179
# this tests the UI reports reverting a file which has been committed
180
# to a revision that did not have it, reports it as being deleted.
181
tree = self.make_branch_and_tree('.')
182
tree.commit('empty commit')
183
self.build_tree(['file'])
185
tree.commit('add file')
186
out, err = self.run_bzr('revert -r -2')
187
self.assertEqual(b'', out)
188
self.assertEqual(b'-D file\n', err)
190
def test_revert_forget_merges(self):
191
# revert --forget-merges removes any pending merges into the tree, but
192
# leaves the files unchanged
193
tree = self.make_branch_and_tree('.')
194
# forget-merges before first commit, though pointless, does not fail
195
self.run_bzr(['revert', '--forget-merges'])
196
self.build_tree(['file'])
197
first_rev_id = tree.commit('initial commit')
198
self.build_tree_contents([('file', b'new content')])
199
existing_parents = tree.get_parent_ids()
200
self.assertEqual([first_rev_id], existing_parents)
201
merged_parents = existing_parents + ['merged-in-rev']
202
tree.set_parent_ids(merged_parents)
203
self.assertEqual(merged_parents, tree.get_parent_ids())
204
self.run_bzr(['revert', '--forget-merges'])
205
self.assertEqual([first_rev_id], tree.get_parent_ids())
206
# changed files are not reverted
207
self.assertFileEqual('new content', 'file')
208
# you can give it the path of a tree
209
self.run_bzr(['revert', '--forget-merges', tree.abspath('.')])