/brz/remove-bazaar

To get this branch, use:
bzr branch http://gegoxaren.bato24.eu/bzr/brz/remove-bazaar

« back to all changes in this revision

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

Merge bzr.dev

Show diffs side-by-side

added added

removed removed

Lines of Context:
1
 
# Copyright (C) 2005, 2007 Canonical Ltd
 
1
# Copyright (C) 2005 by 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
 
17
17
"""Black-box tests for bzr revert."""
18
18
 
19
19
import os
20
20
 
 
21
<<<<<<< TREE
 
22
from bzrlib.workingtree import WorkingTree
 
23
=======
21
24
import bzrlib.osutils
 
25
>>>>>>> MERGE-SOURCE
22
26
from bzrlib.tests.blackbox import ExternalBase
23
27
from bzrlib.trace import mutter
24
 
from bzrlib.workingtree import WorkingTree
25
28
 
26
29
 
27
30
class TestRevert(ExternalBase):
28
31
 
29
32
    def _prepare_tree(self):
30
 
        self.run_bzr('init')
31
 
        self.run_bzr('mkdir dir')
 
33
        self.runbzr('init')
 
34
        self.runbzr('mkdir dir')
32
35
 
33
36
        f = file('dir/file', 'wb')
34
37
        f.write('spam')
35
38
        f.close()
36
 
        self.run_bzr('add dir/file')
 
39
        self.runbzr('add dir/file')
37
40
 
38
 
        self.run_bzr('commit -m1')
 
41
        self.runbzr('commit -m1')
39
42
 
40
43
        # modify file
41
44
        f = file('dir/file', 'wb')
43
46
        f.close()
44
47
 
45
48
        # check status
46
 
        self.assertEquals('modified:\n  dir/file\n', self.run_bzr('status')[0])
 
49
        self.assertEquals('modified:\n  dir/file\n', self.capture('status'))
47
50
 
48
51
    def _prepare_rename_mod_tree(self):
49
 
        self.build_tree(['a/', 'a/b', 'a/c', 'a/d/', 'a/d/e', 'f/', 'f/g',
 
52
        self.build_tree(['a/', 'a/b', 'a/c', 'a/d/', 'a/d/e', 'f/', 'f/g', 
50
53
                         'f/h', 'f/i'])
51
54
        self.run_bzr('init')
52
55
        self.run_bzr('add')
53
 
        self.run_bzr('commit -m 1')
 
56
        self.run_bzr('commit', '-m', '1')
54
57
        wt = WorkingTree.open('.')
55
58
        wt.rename_one('a/b', 'f/b')
56
 
        wt.rename_one('a/d/e', 'f/e')
57
59
        wt.rename_one('a/d', 'f/d')
58
60
        wt.rename_one('f/g', 'a/g')
59
61
        wt.rename_one('f/h', 'h')
66
68
        os.chdir('dir')
67
69
        mutter('cd dir\n')
68
70
 
69
 
        self.assertEquals('1\n', self.run_bzr('revno')[0])
70
 
        self.run_bzr('revert %s file' % param)
 
71
        self.assertEquals('1\n', self.capture('revno'))
 
72
        self.runbzr('revert %s file' % param)
71
73
        self.assertEquals('spam', open('file', 'rb').read())
72
74
 
73
75
    def test_revert_in_subdir(self):
82
84
        os.mkdir('brach')
83
85
        os.chdir('brach')
84
86
        self._prepare_tree()
85
 
        self.run_bzr('checkout --lightweight . ../sprach')
86
 
        self.run_bzr('commit -m more')
 
87
        self.runbzr('checkout --lightweight . ../sprach')
 
88
        self.runbzr('commit -m more')
87
89
        os.chdir('../sprach')
88
 
        self.assertEqual('', self.run_bzr('status')[0])
89
 
        self.run_bzr('revert')
90
 
        self.assertEqual('', self.run_bzr('status')[0])
 
90
        self.assertEqual('', self.capture('status'))
 
91
        self.runbzr('revert')
 
92
        self.assertEqual('', self.capture('status'))
91
93
 
92
94
    def test_revert_dirname(self):
93
95
        """Test that revert DIRECTORY does what's expected"""
94
96
        self._prepare_rename_mod_tree()
95
 
        self.run_bzr('revert a')
 
97
        self.run_bzr('revert', 'a')
96
98
        self.failUnlessExists('a/b')
97
99
        self.failUnlessExists('a/d')
98
100
        self.failIfExists('a/g')
99
 
        self.expectFailure(
100
 
            "j is in the delta revert applies because j was renamed too",
101
 
            self.failUnlessExists, 'j')
 
101
        self.failUnlessExists('j')
102
102
        self.failUnlessExists('h')
103
 
        self.run_bzr('revert f')
 
103
        self.run_bzr('revert', 'f')
104
104
        self.failIfExists('j')
105
105
        self.failIfExists('h')
106
 
        self.failUnlessExists('a/d/e')
107
 
 
108
 
    def test_revert_chatter(self):
109
 
        self._prepare_rename_mod_tree()
110
 
        chatter = self.run_bzr('revert')[1]
111
 
        self.assertEqualDiff(
112
 
            'R   a/g => f/g\n'
113
 
            'R   h => f/h\n'
114
 
            'R   j/ => f/\n'
115
 
            'R   j/b => a/b\n'
116
 
            'R   j/d/ => a/d/\n'
117
 
            'R   j/e => a/d/e\n',
118
 
            chatter)
119
106
 
120
107
    def test_revert(self):
121
108
        self.run_bzr('init')
122
109
 
123
110
        file('hello', 'wt').write('foo')
124
 
        self.run_bzr('add hello')
125
 
        self.run_bzr('commit -m setup hello')
 
111
        self.run_bzr('add', 'hello')
 
112
        self.run_bzr('commit', '-m', 'setup', 'hello')
126
113
 
127
114
        file('goodbye', 'wt').write('baz')
128
 
        self.run_bzr('add goodbye')
129
 
        self.run_bzr('commit -m setup goodbye')
 
115
        self.run_bzr('add', 'goodbye')
 
116
        self.run_bzr('commit', '-m', 'setup', 'goodbye')
130
117
 
131
118
        file('hello', 'wt').write('bar')
132
119
        file('goodbye', 'wt').write('qux')
133
 
        self.run_bzr('revert hello')
 
120
        self.run_bzr('revert', 'hello')
134
121
        self.check_file_contents('hello', 'foo')
135
122
        self.check_file_contents('goodbye', 'qux')
136
123
        self.run_bzr('revert')
137
124
        self.check_file_contents('goodbye', 'baz')
138
125
 
139
126
        os.mkdir('revertdir')
140
 
        self.run_bzr('add revertdir')
141
 
        self.run_bzr('commit -m f')
 
127
        self.run_bzr('add', 'revertdir')
 
128
        self.run_bzr('commit', '-m', 'f')
142
129
        os.rmdir('revertdir')
143
130
        self.run_bzr('revert')
144
131
 
145
132
        if bzrlib.osutils.has_symlinks():
146
133
            os.symlink('/unlikely/to/exist', 'symlink')
147
 
            self.run_bzr('add symlink')
148
 
            self.run_bzr('commit -m f')
 
134
            self.run_bzr('add', 'symlink')
 
135
            self.run_bzr('commit', '-m', 'f')
149
136
            os.unlink('symlink')
150
137
            self.run_bzr('revert')
151
138
            self.failUnlessExists('symlink')
156
143
                             os.readlink('symlink'))
157
144
        else:
158
145
            self.log("skipping revert symlink tests")
159
 
 
 
146
        
160
147
        file('hello', 'wt').write('xyz')
161
 
        self.run_bzr('commit -m xyz hello')
162
 
        self.run_bzr('revert -r 1 hello')
 
148
        self.run_bzr('commit', '-m', 'xyz', 'hello')
 
149
        self.run_bzr('revert', '-r', '1', 'hello')
163
150
        self.check_file_contents('hello', 'foo')
164
 
        self.run_bzr('revert hello')
 
151
        self.run_bzr('revert', 'hello')
165
152
        self.check_file_contents('hello', 'xyz')
166
153
        os.chdir('revertdir')
167
154
        self.run_bzr('revert')
168
155
        os.chdir('..')
169
156
 
170
 
    def test_revert_newly_added(self):
171
 
        # this tests the UI reports reverting a newly added file
172
 
        # correct (such files are not deleted)
173
 
        tree = self.make_branch_and_tree('.')
174
 
        self.build_tree(['file'])
175
 
        tree.add(['file'])
176
 
        out, err = self.run_bzr('revert')
177
 
        self.assertEqual('', out)
178
 
        self.assertEqual('-   file\n', err)
179
 
 
180
 
    def test_revert_removing_file(self):
181
 
        # this tests the UI reports reverting a file which has been committed
182
 
        # to a revision that did not have it, reports it as being deleted.
183
 
        tree = self.make_branch_and_tree('.')
184
 
        tree.commit('empty commit')
185
 
        self.build_tree(['file'])
186
 
        tree.add(['file'])
187
 
        tree.commit('add file')
188
 
        out, err = self.run_bzr('revert -r -2')
189
 
        self.assertEqual('', out)
190
 
        self.assertEqual('-D  file\n', err)
191
 
 
192
 
    def test_revert_forget_merges(self):
193
 
        # revert --forget-merges removes any pending merges into the tree, but
194
 
        # leaves the files unchanged
195
 
        tree = self.make_branch_and_tree('.')
196
 
        # forget-merges before first commit, though pointless, does not fail
197
 
        self.run_bzr(['revert', '--forget-merges'])
198
 
        self.build_tree(['file'])
199
 
        first_rev_id = tree.commit('initial commit')
200
 
        self.build_tree_contents([('file', 'new content')])
201
 
        existing_parents = tree.get_parent_ids()
202
 
        self.assertEquals([first_rev_id], existing_parents)
203
 
        merged_parents = existing_parents + ['merged-in-rev']
204
 
        tree.set_parent_ids(merged_parents)
205
 
        self.assertEquals(merged_parents, tree.get_parent_ids())
206
 
        self.run_bzr(['revert', '--forget-merges'])
207
 
        self.assertEquals([first_rev_id], tree.get_parent_ids())
208
 
        # changed files are not reverted
209
 
        self.assertFileEqual('new content', 'file')
210
 
        # you can give it the path of a tree
211
 
        self.run_bzr(['revert', '--forget-merges', tree.abspath('.')])