/brz/remove-bazaar

To get this branch, use:
bzr branch http://gegoxaren.bato24.eu/bzr/brz/remove-bazaar
0.64.1 by Ian Clatworthy
1st cut: gfi parser + --info processing method
1
# Copyright (C) 2008 Canonical Ltd
2
#
3
# This program is free software; you can redistribute it and/or modify
4
# it under the terms of the GNU General Public License as published by
5
# the Free Software Foundation; either version 2 of the License, or
6
# (at your option) any later version.
7
#
8
# This program is distributed in the hope that it will be useful,
9
# but WITHOUT ANY WARRANTY; without even the implied warranty of
10
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
11
# GNU General Public License for more details.
12
#
13
# You should have received a copy of the GNU General Public License
14
# along with this program; if not, write to the Free Software
15
# Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307  USA
16
17
"""Test the Import parsing"""
18
19
import StringIO
20
21
from bzrlib import tests
22
23
from bzrlib.plugins.fastimport import (
24
    errors,
25
    parser,
26
    )
27
28
29
class TestLineBasedParser(tests.TestCase):
30
31
    def test_push_line(self):
32
        s = StringIO.StringIO("foo\nbar\nbaz\n")
33
        p = parser.LineBasedParser(s)
34
        self.assertEqual('foo', p.next_line())
35
        self.assertEqual('bar', p.next_line())
36
        p.push_line('bar')
37
        self.assertEqual('bar', p.next_line())
38
        self.assertEqual('baz', p.next_line())
39
        self.assertEqual(None, p.next_line())
40
41
    def test_read_bytes(self):
42
        s = StringIO.StringIO("foo\nbar\nbaz\n")
43
        p = parser.LineBasedParser(s)
44
        self.assertEqual('fo', p.read_bytes(2))
45
        self.assertEqual('o\nb', p.read_bytes(3))
46
        self.assertEqual('ar', p.next_line())
47
        # Test that the line buffer is ignored
48
        p.push_line('bar')
49
        self.assertEqual('baz', p.read_bytes(3))
50
        # Test missing bytes
51
        self.assertRaises(errors.MissingBytes, p.read_bytes, 10)
52
53
    def test_read_until(self):
54
        # TODO
55
        return
56
        s = StringIO.StringIO("foo\nbar\nbaz\nabc\ndef\nghi\n")
57
        p = parser.LineBasedParser(s)
58
        self.assertEqual('foo\nbar', p.read_until('baz'))
59
        self.assertEqual('abc', p.next_line())
60
        # Test that the line buffer is ignored
61
        p.push_line('abc')
62
        self.assertEqual('def', p.read_until('ghi'))
63
        # Test missing terminator
64
        self.assertRaises(errors.MissingTerminator, p.read_until('>>>'))
65
66
67
# Sample text
68
_sample_import_text = """
69
progress completed
70
# Test blob formats
71
blob
72
mark :1
73
data 4
0.65.5 by James Westby
Make the parser handle multiple words in the committer name.
74
aaaablob
0.64.1 by Ian Clatworthy
1st cut: gfi parser + --info processing method
75
data 5
76
bbbbb
77
# Commit formats
0.65.5 by James Westby
Make the parser handle multiple words in the committer name.
78
commit refs/heads/master
79
mark :2
80
committer bugs bunny <bugs@bunny.org> now
0.64.1 by Ian Clatworthy
1st cut: gfi parser + --info processing method
81
data 14
82
initial import
83
M 644 inline README
84
data 18
85
Welcome from bugs
0.65.5 by James Westby
Make the parser handle multiple words in the committer name.
86
commit refs/heads/master
0.65.2 by James Westby
The space between the author and email is optional in committer.
87
committer <bugs@bunny.org> now
88
data 13
89
second commit
0.65.5 by James Westby
Make the parser handle multiple words in the committer name.
90
from :2
0.65.2 by James Westby
The space between the author and email is optional in committer.
91
M 644 inline README
0.65.5 by James Westby
Make the parser handle multiple words in the committer name.
92
data 23
0.65.2 by James Westby
The space between the author and email is optional in committer.
93
Welcome from bugs, etc.
0.64.1 by Ian Clatworthy
1st cut: gfi parser + --info processing method
94
# Miscellaneous
95
checkpoint
96
progress completed
0.64.172 by Ian Clatworthy
handle commit commands with no from clause and no sub-commands
97
# Test a commit without sub-commands (bug #351717)
98
commit refs/heads/master
99
mark :3
100
author <bugs@bunny.org> now
101
committer <bugs@bunny.org> now
102
data 20
103
first commit, empty
0.88.1 by Samuel Bronson
Add a test for bug #400960.
104
# Test a commit with a heredoc-style (delimited_data) messsage (bug #400960)
105
commit refs/heads/master
106
mark :4
107
author <bugs@bunny.org> now
108
committer <bugs@bunny.org> now
109
data <<EOF
110
Commit with heredoc-style message
111
EOF
0.64.229 by Ian Clatworthy
Handle git submodules in the stream by warning about + ignoring them
112
# Test a "submodule"/tree-reference
113
commit refs/heads/master
114
mark :5
115
author <bugs@bunny.org> now
116
committer <bugs@bunny.org> now
117
data 15
118
submodule test
119
M 160000 rev-id tree-id
0.64.1 by Ian Clatworthy
1st cut: gfi parser + --info processing method
120
"""
121
122
123
class TestImportParser(tests.TestCase):
124
125
    def test_iter_commands(self):
126
        s = StringIO.StringIO(_sample_import_text)
127
        p = parser.ImportParser(s)
0.64.10 by Ian Clatworthy
1st cut are dequoting paths
128
        result = []
0.64.1 by Ian Clatworthy
1st cut: gfi parser + --info processing method
129
        for cmd in p.iter_commands():
0.64.10 by Ian Clatworthy
1st cut are dequoting paths
130
            result.append(cmd)
0.64.1 by Ian Clatworthy
1st cut: gfi parser + --info processing method
131
            if cmd.name == 'commit':
132
                for fc in cmd.file_iter():
0.64.10 by Ian Clatworthy
1st cut are dequoting paths
133
                    result.append(fc)
0.64.229 by Ian Clatworthy
Handle git submodules in the stream by warning about + ignoring them
134
        self.assertEqual(len(result), 13)
0.64.172 by Ian Clatworthy
handle commit commands with no from clause and no sub-commands
135
        cmd1 = result.pop(0)
0.64.10 by Ian Clatworthy
1st cut are dequoting paths
136
        self.assertEqual('progress', cmd1.name)
0.65.5 by James Westby
Make the parser handle multiple words in the committer name.
137
        self.assertEqual('completed', cmd1.message)
0.64.172 by Ian Clatworthy
handle commit commands with no from clause and no sub-commands
138
        cmd2 = result.pop(0)
0.65.5 by James Westby
Make the parser handle multiple words in the committer name.
139
        self.assertEqual('blob', cmd2.name)
140
        self.assertEqual('1', cmd2.mark)
141
        self.assertEqual(':1', cmd2.id)
142
        self.assertEqual('aaaa', cmd2.data)
143
        self.assertEqual(4, cmd2.lineno)
0.64.172 by Ian Clatworthy
handle commit commands with no from clause and no sub-commands
144
        cmd3 = result.pop(0)
0.65.5 by James Westby
Make the parser handle multiple words in the committer name.
145
        self.assertEqual('blob', cmd3.name)
146
        self.assertEqual('@7', cmd3.id)
147
        self.assertEqual(None, cmd3.mark)
148
        self.assertEqual('bbbbb', cmd3.data)
149
        self.assertEqual(7, cmd3.lineno)
0.64.172 by Ian Clatworthy
handle commit commands with no from clause and no sub-commands
150
        cmd4 = result.pop(0)
0.65.5 by James Westby
Make the parser handle multiple words in the committer name.
151
        self.assertEqual('commit', cmd4.name)
152
        self.assertEqual('2', cmd4.mark)
153
        self.assertEqual(':2', cmd4.id)
154
        self.assertEqual('initial import', cmd4.message)
155
        self.assertEqual('bugs bunny', cmd4.committer[0])
156
        self.assertEqual('bugs@bunny.org', cmd4.committer[1])
157
        # FIXME: check timestamp and timezone as well
158
        self.assertEqual(None, cmd4.author)
159
        self.assertEqual(11, cmd4.lineno)
160
        self.assertEqual('refs/heads/master', cmd4.ref)
0.64.71 by Ian Clatworthy
fix tests to use new CommitCommand constructor
161
        self.assertEqual(None, cmd4.from_)
162
        self.assertEqual([], cmd4.merges)
0.64.172 by Ian Clatworthy
handle commit commands with no from clause and no sub-commands
163
        file_cmd1 = result.pop(0)
0.65.5 by James Westby
Make the parser handle multiple words in the committer name.
164
        self.assertEqual('filemodify', file_cmd1.name)
165
        self.assertEqual('README', file_cmd1.path)
166
        self.assertEqual('file', file_cmd1.kind)
167
        self.assertEqual(False, file_cmd1.is_executable)
168
        self.assertEqual('Welcome from bugs\n', file_cmd1.data)
0.64.172 by Ian Clatworthy
handle commit commands with no from clause and no sub-commands
169
        cmd5 = result.pop(0)
0.65.5 by James Westby
Make the parser handle multiple words in the committer name.
170
        self.assertEqual('commit', cmd5.name)
171
        self.assertEqual(None, cmd5.mark)
172
        self.assertEqual('@19', cmd5.id)
173
        self.assertEqual('second commit', cmd5.message)
174
        self.assertEqual('', cmd5.committer[0])
175
        self.assertEqual('bugs@bunny.org', cmd5.committer[1])
176
        # FIXME: check timestamp and timezone as well
177
        self.assertEqual(None, cmd5.author)
178
        self.assertEqual(19, cmd5.lineno)
179
        self.assertEqual('refs/heads/master', cmd5.ref)
0.64.71 by Ian Clatworthy
fix tests to use new CommitCommand constructor
180
        self.assertEqual(':2', cmd5.from_)
181
        self.assertEqual([], cmd5.merges)
0.64.172 by Ian Clatworthy
handle commit commands with no from clause and no sub-commands
182
        file_cmd2 = result.pop(0)
0.65.5 by James Westby
Make the parser handle multiple words in the committer name.
183
        self.assertEqual('filemodify', file_cmd2.name)
184
        self.assertEqual('README', file_cmd2.path)
185
        self.assertEqual('file', file_cmd2.kind)
186
        self.assertEqual(False, file_cmd2.is_executable)
187
        self.assertEqual('Welcome from bugs, etc.', file_cmd2.data)
0.64.172 by Ian Clatworthy
handle commit commands with no from clause and no sub-commands
188
        cmd6 = result.pop(0)
0.65.5 by James Westby
Make the parser handle multiple words in the committer name.
189
        self.assertEqual(cmd6.name, 'checkpoint')
0.64.172 by Ian Clatworthy
handle commit commands with no from clause and no sub-commands
190
        cmd7 = result.pop(0)
0.65.5 by James Westby
Make the parser handle multiple words in the committer name.
191
        self.assertEqual('progress', cmd7.name)
192
        self.assertEqual('completed', cmd7.message)
0.64.172 by Ian Clatworthy
handle commit commands with no from clause and no sub-commands
193
        cmd = result.pop(0)
194
        self.assertEqual('commit', cmd.name)
195
        self.assertEqual('3', cmd.mark)
196
        self.assertEqual(None, cmd.from_)
0.88.1 by Samuel Bronson
Add a test for bug #400960.
197
        cmd = result.pop(0)
198
        self.assertEqual('commit', cmd.name)
199
        self.assertEqual('4', cmd.mark)
200
        self.assertEqual('Commit with heredoc-style message\n', cmd.message)
0.64.229 by Ian Clatworthy
Handle git submodules in the stream by warning about + ignoring them
201
        cmd = result.pop(0)
202
        self.assertEqual('commit', cmd.name)
203
        self.assertEqual('5', cmd.mark)
204
        self.assertEqual('submodule test\n', cmd.message)
205
        file_cmd1 = result.pop(0)
206
        self.assertEqual('filemodify', file_cmd1.name)
207
        self.assertEqual('tree-id', file_cmd1.path)
208
        self.assertEqual('tree-reference', file_cmd1.kind)
209
        self.assertEqual(False, file_cmd1.is_executable)
210
        self.assertEqual("rev-id", file_cmd1.dataref)
0.64.10 by Ian Clatworthy
1st cut are dequoting paths
211
212
213
class TestStringParsing(tests.TestCase):
214
215
    def test_unquote(self):
216
        s = r'hello \"sweet\" wo\\r\tld'
217
        self.assertEquals(r'hello "sweet" wo\r' + "\tld",
218
            parser._unquote_c_string(s))
0.64.175 by Ian Clatworthy
fix parsing when a rename old-path has spaces in it
219
220
221
class TestPathPairParsing(tests.TestCase):
222
223
    def test_path_pair_simple(self):
224
        p = parser.ImportParser("")
225
        self.assertEqual(['foo', 'bar'], p._path_pair("foo bar"))
226
227
    def test_path_pair_spaces_in_first(self):
228
        p = parser.ImportParser("")
229
        self.assertEqual(['foo bar', 'baz'],
230
            p._path_pair('"foo bar" baz'))