~abentley/bzrtools/bzrtools.dev

« back to all changes in this revision

Viewing changes to tests/blackbox.py

  • Committer: Max Bowsher
  • Date: 2009-11-13 00:43:08 UTC
  • mto: This revision was merged to the branch mainline in revision 739.
  • Revision ID: maxb@f2s.com-20091113004308-4dcwu1kwt3lhf1kp
Having discovered that bzr-builddeb import_dsc.py is a horrid copy-paste job of bzrtools upstream_import.py, restructure the change to minimize divergence from it.

Show diffs side-by-side

added added

removed removed

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