~abentley/bzrtools/bzrtools.dev

« back to all changes in this revision

Viewing changes to tests/blackbox.py

  • Committer: Aaron Bentley
  • Date: 2008-01-23 23:09:27 UTC
  • Revision ID: aaron@aaronbentley.com-20080123230927-7wtn8mvyyuhs5gq3
Remove unneeded imports from dotgraph

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