~abentley/bzrtools/bzrtools.dev

« back to all changes in this revision

Viewing changes to tests/blackbox.py

  • Committer: Aaron Bentley
  • Date: 2005-09-13 22:49:40 UTC
  • mto: (147.1.21)
  • mto: This revision was merged to the branch mainline in revision 154.
  • Revision ID: abentley@panoramicfeedback.com-20050913224940-c6db07f39dd303be
Updated docs, obsoleted old executibles

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)