~abentley/bzrtools/bzrtools.dev

« back to all changes in this revision

Viewing changes to tests/blackbox.py

  • Committer: Michael Ellerman
  • Date: 2006-06-21 13:51:45 UTC
  • mto: This revision was merged to the branch mainline in revision 405.
  • Revision ID: michael@ellerman.id.au-20060621135145-8691d8247e9fcc80
Parse ~/.colordiffrc for colour information if it's there.

Show diffs side-by-side

added added

removed removed

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