~abentley/bzrtools/bzrtools.dev

« back to all changes in this revision

Viewing changes to tests/blackbox.py

  • Committer: Aaron Bentley
  • Date: 2013-08-20 03:02:43 UTC
  • Revision ID: aaron@aaronbentley.com-20130820030243-r8v1xfbcnd8f10p4
Fix zap command for 2.6/7

Show diffs side-by-side

added added

removed removed

Lines of Context:
1
 
from bzrlib.tests.blackbox import ExternalBase
 
1
import os
 
2
import os.path
2
3
from unittest import makeSuite
3
 
import os.path
4
 
class TestBzrTools(ExternalBase):
 
4
 
 
5
from bzrlib import branch, osutils, workingtree
 
6
from bzrlib.config import LocationConfig
 
7
from bzrlib.transport import get_transport
 
8
from bzrlib.tests import (
 
9
    TestCaseWithTransport,
 
10
    )
 
11
from bzrlib.plugins.bzrtools import command
 
12
 
 
13
try:
 
14
    from bzrlib.tests.features import (
 
15
        HardlinkFeature,
 
16
        ModuleAvailableFeature,
 
17
        )
 
18
except ImportError: # bzr < 2.5
 
19
    from bzrlib.tests import (
 
20
        HardlinkFeature,
 
21
        ModuleAvailableFeature,
 
22
        )
 
23
 
 
24
 
 
25
LzmaFeature = ModuleAvailableFeature("lzma")
 
26
 
 
27
 
 
28
class TestBzrTools(TestCaseWithTransport):
 
29
 
 
30
    def setUp(self):
 
31
        TestCaseWithTransport.setUp(self)
 
32
        command._testing = True
 
33
        self.addCleanup(command._stop_testing)
 
34
 
5
35
    @staticmethod
6
36
    def touch(filename):
7
37
        file(filename, 'wb').write('')
8
38
 
9
 
    def test_clean_tree(self):
10
 
        self.runbzr('init')
11
 
        self.touch('name')
12
 
        self.touch('name~')
13
 
        assert os.path.lexists('name~')
14
 
        self.touch('name.pyc')
15
 
        self.runbzr('clean-tree')
16
 
        assert os.path.lexists('name~')
17
 
        assert not os.path.lexists('name')
18
 
        self.runbzr('clean-tree --detritus')
19
 
        assert not os.path.lexists('name~')
20
 
        assert os.path.lexists('name.pyc')
21
 
        self.runbzr('clean-tree --ignored')
22
 
        assert not os.path.lexists('name.pyc')
23
 
 
24
39
    def test_shelve(self):
25
 
        self.runbzr('init')
26
 
        self.runbzr('commit -m uc --unchanged')
27
 
        self.runbzr('shelve -r 1 -m foo --all', retcode=3)
 
40
        self.run_bzr('init')
 
41
        self.run_bzr('commit -m uc --unchanged')
 
42
        self.run_bzr('shelve1 -r 1 -m foo --all', retcode=3)
28
43
        file('foo', 'wb').write('foo')
29
 
        self.runbzr('add foo')
30
 
        self.runbzr('commit -m foo')
31
 
        self.runbzr('shelve -r 1 -m foo --all', retcode=0)
 
44
        self.run_bzr('add foo')
 
45
        self.run_bzr('commit -m foo')
 
46
        self.run_bzr('shelve1 -r 1 -m foo --all', retcode=0)
32
47
 
33
48
    def test_fetch_ghosts(self):
34
 
        self.runbzr('init')
35
 
        self.runbzr('fetch-ghosts .')
 
49
        self.run_bzr('init')
 
50
        self.run_bzr('fetch-ghosts .')
 
51
 
 
52
    def test_fetch_ghosts_with_saved(self):
 
53
        wt = self.make_branch_and_tree('.')
 
54
        wt.branch.set_parent('.')
 
55
        self.run_bzr('fetch-ghosts')
36
56
 
37
57
    def test_patch(self):
38
 
        self.runbzr('init')
 
58
        self.run_bzr('init')
39
59
        file('myfile', 'wb').write('hello')
40
 
        self.runbzr('add')
41
 
        self.runbzr('commit -m hello')
 
60
        self.run_bzr('add')
 
61
        self.run_bzr('commit -m hello')
42
62
        file('myfile', 'wb').write('goodbye')
43
 
        file('mypatch', 'wb').write(self.runbzr('diff', retcode=1, backtick=1))
44
 
        self.runbzr('revert')
 
63
        file('mypatch', 'wb').write(self.run_bzr('diff', retcode=1)[0])
 
64
        self.run_bzr('revert')
45
65
        assert file('myfile', 'rb').read() == 'hello'
46
 
        self.runbzr('patch mypatch')
 
66
        self.run_bzr('patch --silent mypatch')
47
67
        assert file('myfile', 'rb').read() == 'goodbye'
48
68
 
49
69
    def test_branch_history(self):
50
 
        self.runbzr('init')
 
70
        self.run_bzr('init')
51
71
        file('myfile', 'wb').write('hello')
52
 
        self.runbzr('add')
53
 
        self.runbzr('commit -m hello')
54
 
        self.runbzr('branch-history')
 
72
        self.run_bzr('add')
 
73
        self.run_bzr('commit -m hello')
 
74
        self.run_bzr('branch-history')
55
75
 
56
76
    def test_branch_history(self):
57
 
        self.runbzr('init')
 
77
        self.run_bzr('init')
58
78
        file('myfile', 'wb').write('hello')
59
 
        self.runbzr('add')
60
 
        self.runbzr('commit -m hello')
61
 
        self.runbzr('graph-ancestry . graph.dot')
62
 
        self.runbzr('branch . my_branch')
63
 
        self.runbzr('graph-ancestry . graph.dot --merge-branch my_branch')
 
79
        self.run_bzr('add')
 
80
        self.run_bzr('commit -m hello')
 
81
        self.run_bzr('graph-ancestry . graph.dot')
 
82
        self.run_bzr('branch . my_branch')
 
83
        self.run_bzr('graph-ancestry . graph.dot --merge-branch my_branch')
64
84
 
65
85
    def test_fetch_ghosts(self):
66
 
        self.runbzr('init')
 
86
        self.run_bzr('init')
67
87
        file('myfile', 'wb').write('hello')
68
 
        self.runbzr('add')
69
 
        self.runbzr('commit -m hello')
70
 
        self.runbzr('branch . my_branch')
71
 
        self.runbzr('fetch-ghosts my_branch')
 
88
        self.run_bzr('add')
 
89
        self.run_bzr('commit -m hello')
 
90
        self.run_bzr('branch . my_branch')
 
91
        self.run_bzr('fetch-ghosts my_branch')
72
92
 
73
93
    def test_zap(self):
74
 
        self.runbzr('init source')
75
 
        self.runbzr('checkout --lightweight source checkout')
76
 
        self.runbzr('zap checkout')
 
94
        self.run_bzr('init source')
 
95
        self.run_bzr('checkout --lightweight source checkout')
 
96
        self.run_bzr('zap checkout')
77
97
        self.assertIs(False, os.path.exists('checkout'))
78
98
        self.assertIs(True, os.path.exists('source'))
79
99
 
 
100
    def test_zap_modified(self):
 
101
        tree = self.make_branch_and_tree('source')
 
102
        checkout = tree.branch.create_checkout('checkout', lightweight=True)
 
103
        self.build_tree(['checkout/file'])
 
104
        checkout.add('file')
 
105
        self.run_bzr_error(('This checkout has uncommitted changes',),
 
106
                           'zap checkout')
 
107
        self.assertPathExists('checkout')
 
108
        self.run_bzr('zap checkout --force')
 
109
        self.assertPathDoesNotExist('checkout')
 
110
        self.assertPathExists('source')
 
111
 
80
112
    def test_zap_branch(self):
81
 
        self.runbzr('init source')
82
 
        self.runbzr('checkout --lightweight source checkout')
83
 
        self.runbzr('zap --branch checkout', retcode=3)
 
113
        self.run_bzr('init source')
 
114
        self.run_bzr('checkout --lightweight source checkout')
 
115
        self.run_bzr('zap --branch checkout', retcode=3)
84
116
        self.assertIs(True, os.path.exists('checkout'))
85
117
        self.assertIs(True, os.path.exists('source'))
86
 
        self.runbzr('branch source source2')
87
 
        self.runbzr('checkout --lightweight source2 checkout2')
88
 
        self.runbzr('zap --branch checkout2')
 
118
        self.run_bzr('branch source source2')
 
119
        self.run_bzr('checkout --lightweight source2 checkout2')
 
120
        self.run_bzr('zap --branch checkout2')
89
121
        self.assertIs(False, os.path.exists('checkout2'))
90
122
        self.assertIs(False, os.path.exists('source2'))
91
123
 
92
 
    def test_branches(self):
93
 
        self.runbzr('init source')
94
 
        self.runbzr('init source/subsource')
95
 
        self.runbzr('checkout --lightweight source checkout')
96
 
        self.runbzr('init checkout/subcheckout')
97
 
        self.runbzr('init checkout/.bzr/subcheckout')
98
 
        out = self.capture('branches')
 
124
    def test_list_branches(self):
 
125
        self.run_bzr('init source')
 
126
        self.run_bzr('init source/subsource')
 
127
        self.run_bzr('checkout --lightweight source checkout')
 
128
        self.run_bzr('init checkout/subcheckout')
 
129
        self.run_bzr('init checkout/.bzr/subcheckout')
 
130
        out = self.run_bzr('list-branches')[0]
99
131
        lines = out.split('\n')
100
132
        self.assertIs(True, 'source' in lines)
101
133
        self.assertIs(True, 'source/subsource' in lines)
102
134
        self.assertIs(True, 'checkout/subcheckout' in lines)
103
135
        self.assertIs(True, 'checkout' not in lines)
104
 
        self.assertIs(True, 'checkout/.bzr/subcheckout' not in lines)
105
136
 
106
137
    def test_import_upstream(self):
107
 
        self.runbzr('init source')
 
138
        self.run_bzr('init source')
108
139
        os.mkdir('source/src')
109
140
        f = file('source/src/myfile', 'wb')
110
141
        f.write('hello?')
111
142
        f.close()
112
143
        os.chdir('source')
113
 
        self.runbzr('add')
114
 
        self.runbzr('commit -m hello')
115
 
        self.runbzr('export ../source-0.1.tar.gz')
116
 
        self.runbzr('export ../source-0.1.tar.bz2')
117
 
        self.runbzr('init ../import')
 
144
        self.run_bzr('add')
 
145
        self.run_bzr('commit -m hello')
 
146
        self.run_bzr('export ../source-0.1.tar.gz')
 
147
        self.run_bzr('export ../source-0.1.tar.bz2')
 
148
        self.run_bzr('export ../source-0.1')
 
149
        self.run_bzr('init ../import')
118
150
        os.chdir('../import')
119
 
        self.runbzr('import ../source-0.1.tar.gz')
120
 
        self.failUnlessExists('src/myfile')
121
 
        result = self.runbzr('import ../source-0.1.tar.gz', retcode=3)[1]
 
151
        self.run_bzr('import ../source-0.1.tar.gz')
 
152
        self.assertPathExists('src/myfile')
 
153
        result = self.run_bzr('import ../source-0.1.tar.gz', retcode=3)[1]
122
154
        self.assertContainsRe(result, 'Working tree has uncommitted changes')
123
 
        self.runbzr('commit -m commit')
124
 
        self.runbzr('import ../source-0.1.tar.gz')
 
155
        self.run_bzr('commit -m commit')
 
156
        self.run_bzr('import ../source-0.1.tar.gz')
125
157
        os.chdir('..')
126
 
        self.runbzr('init import2')
127
 
        self.runbzr('import source-0.1.tar.gz import2')
128
 
        self.failUnlessExists('import2/src/myfile')
129
 
        self.runbzr('import source-0.1.tar.gz import3')
130
 
        self.failUnlessExists('import3/src/myfile')
131
 
        self.runbzr('import source-0.1.tar.bz2 import4')
132
 
        self.failUnlessExists('import4/src/myfile')
 
158
        self.run_bzr('init import2')
 
159
        self.run_bzr('import source-0.1.tar.gz import2')
 
160
        self.assertPathExists('import2/src/myfile')
 
161
        self.run_bzr('import source-0.1.tar.gz import3')
 
162
        self.assertPathExists('import3/src/myfile')
 
163
        self.run_bzr('import source-0.1.tar.bz2 import4')
 
164
        self.assertPathExists('import4/src/myfile')
 
165
        self.run_bzr('import source-0.1 import5')
 
166
        self.assertPathExists('import5/src/myfile')
133
167
 
134
 
    def test_shove(self):
135
 
        self.runbzr('init source')
136
 
        f = file('source/file', 'wb')
137
 
        f.write('hello\n')
138
 
        f.close()
139
 
        self.runbzr('add source/file')
140
 
        self.runbzr('commit source -m foo')
141
 
        self.runbzr('branch source target1')
142
 
        self.runbzr('branch source target2')
143
 
        f = file('source/file', 'wb')
144
 
        f.write('goodbye\n')
145
 
        f.close()
146
 
        self.runbzr('shove source target1')
147
 
        f = file('target1/file', 'rb')
148
 
        self.assertEqual(f.read(), 'goodbye\n')
 
168
    def test_import_upstream_lzma(self):
 
169
        self.requireFeature(LzmaFeature)
 
170
        self.run_bzr('init source')
 
171
        os.mkdir('source/src')
 
172
        f = file('source/src/myfile', 'wb')
 
173
        f.write('hello?')
149
174
        f.close()
150
175
        os.chdir('source')
151
 
        self.runbzr('shove target2', retcode=3)
152
 
        self.runbzr('shove ../target2')
153
 
        f = file('../target2/file', 'rb')
154
 
        self.assertEqual(f.read(), 'goodbye\n')
155
 
        f.close()
 
176
        self.run_bzr('add')
 
177
        self.run_bzr('commit -m hello')
 
178
        self.run_bzr('export ../source-0.1.tar.lzma')
 
179
        self.run_bzr('export ../source-0.1.tar.xz')
 
180
        os.chdir('..')
 
181
        self.run_bzr('import source-0.1.tar.lzma import1')
 
182
        self.assertPathExists('import1/src/myfile')
 
183
        self.run_bzr('import source-0.1.tar.xz import2')
 
184
        self.assertPathExists('import2/src/myfile')
 
185
 
 
186
    def test_cbranch(self):
 
187
        source = self.make_branch_and_tree('source')
 
188
        config = LocationConfig(osutils.abspath('target'))
 
189
        config.set_user_option('cbranch_target', 'target_branch')
 
190
        self.run_bzr('cbranch source target')
 
191
        checkout = workingtree.WorkingTree.open('target')
 
192
        self.assertEqual(checkout.branch.base,
 
193
                         get_transport('target').base)
 
194
        self.assertEqual(checkout.branch.get_master_branch().base,
 
195
                         get_transport('target_branch').base)
 
196
        self.assertEqual(checkout.branch.get_master_branch().get_parent(),
 
197
                         get_transport('source').base)
 
198
 
 
199
    def test_cbranch_hardlink(self):
 
200
        self.requireFeature(HardlinkFeature)
 
201
        # Later formats don't support hardlinks.  Boo!
 
202
        source = self.make_branch_and_tree('source', format='1.9')
 
203
        self.build_tree(['source/file'])
 
204
        source.add('file')
 
205
        source.commit('added file')
 
206
        config = LocationConfig(osutils.abspath('target'))
 
207
        config.set_user_option('cbranch_target', 'target_branch')
 
208
        self.run_bzr('cbranch source target --lightweight')
 
209
        checkout = workingtree.WorkingTree.open('target')
 
210
        self.assertNotEqual(os.lstat(checkout.abspath('file')).st_ino,
 
211
                            os.lstat(source.abspath('file')).st_ino)
 
212
        config = LocationConfig(osutils.abspath('target2'))
 
213
        config.set_user_option('cbranch_target', 'target_branch2')
 
214
        self.run_bzr('cbranch source target2 --lightweight --hardlink')
 
215
        checkout2 = workingtree.WorkingTree.open('target2')
 
216
        self.assertEqual(os.lstat(checkout2.abspath('file')).st_ino,
 
217
                         os.lstat(source.abspath('file')).st_ino)
 
218
 
 
219
    def test_create_mirror(self):
 
220
        source = self.make_branch_and_tree('source')
 
221
        source.commit('message')
 
222
        self.run_bzr('create-mirror source target')
 
223
        target = branch.Branch.open('target')
 
224
        self.assertEqual(source.last_revision(), target.last_revision())
 
225
        self.assertEqual(source.branch.base, target.get_public_branch())
 
226
 
156
227
 
157
228
def test_suite():
158
229
    return makeSuite(TestBzrTools)