/brz/remove-bazaar

To get this branch, use:
bzr branch http://gegoxaren.bato24.eu/bzr/brz/remove-bazaar
1540.3.15 by Martin Pool
[merge] large merge to sync with bzr.dev
1
# Copyright (C) 2005, 2006 Canonical
1540.3.24 by Martin Pool
Add new protocol 'http+pycurl' that always uses PyCurl.
2
#
1540.3.15 by Martin Pool
[merge] large merge to sync with bzr.dev
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.
1540.3.24 by Martin Pool
Add new protocol 'http+pycurl' that always uses PyCurl.
7
#
1540.3.15 by Martin Pool
[merge] large merge to sync with bzr.dev
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.
1540.3.24 by Martin Pool
Add new protocol 'http+pycurl' that always uses PyCurl.
12
#
1540.3.15 by Martin Pool
[merge] large merge to sync with bzr.dev
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
1185.16.68 by Martin Pool
- http url fixes suggested by Robey Pointer, and tests
16
1540.3.3 by Martin Pool
Review updates of pycurl transport
17
# FIXME: This test should be repeated for each available http client
18
# implementation; at the moment we have urllib and pycurl.
19
1540.3.22 by Martin Pool
[patch] Add TestCase.assertIsInstance
20
# TODO: Should be renamed to bzrlib.transport.http.tests?
21
2000.2.2 by John Arbash Meinel
Update the urllib.has test.
22
import socket
23
1553.1.2 by James Henstridge
Add a test to make sure the user-agent header is being sent correctly.
24
import bzrlib
2004.1.1 by vila
Connection sharing, with redirection. without authentification.
25
from bzrlib.errors import (DependencyNotPresent,
26
                           ConnectionError,
27
                           )
1540.3.30 by Martin Pool
Fix up bogus-url tests for broken dns servers, and error imports
28
from bzrlib.tests import TestCase, TestSkipped
1540.3.23 by Martin Pool
Allow urls like http+pycurl://host/ to use a particular impl
29
from bzrlib.transport import Transport
1786.1.23 by John Arbash Meinel
Move offset_to_http_ranges back onto HttpTransportBase, clarify tests.
30
from bzrlib.transport.http import extract_auth, HttpTransportBase
1540.3.26 by Martin Pool
[merge] bzr.dev; pycurl not updated for readv yet
31
from bzrlib.transport.http._urllib import HttpTransport_urllib
1553.1.3 by James Henstridge
Make bzrlib.transport.http.HttpServer output referer and user agent as in
32
from bzrlib.tests.HTTPTestUtil import TestCaseWithWebserver
1185.40.20 by Robey Pointer
allow user:pass@ info in http urls to be used for auth; this should be easily expandable later to use auth config files
33
1786.1.8 by John Arbash Meinel
[merge] Johan Rydberg test updates
34
1185.40.20 by Robey Pointer
allow user:pass@ info in http urls to be used for auth; this should be easily expandable later to use auth config files
35
class FakeManager (object):
1786.1.8 by John Arbash Meinel
[merge] Johan Rydberg test updates
36
1185.40.20 by Robey Pointer
allow user:pass@ info in http urls to be used for auth; this should be easily expandable later to use auth config files
37
    def __init__(self):
38
        self.credentials = []
39
        
40
    def add_password(self, realm, host, username, password):
41
        self.credentials.append([realm, host, username, password])
42
1553.1.2 by James Henstridge
Add a test to make sure the user-agent header is being sent correctly.
43
1185.16.68 by Martin Pool
- http url fixes suggested by Robey Pointer, and tests
44
class TestHttpUrls(TestCase):
1786.1.8 by John Arbash Meinel
[merge] Johan Rydberg test updates
45
1185.40.20 by Robey Pointer
allow user:pass@ info in http urls to be used for auth; this should be easily expandable later to use auth config files
46
    def test_url_parsing(self):
47
        f = FakeManager()
48
        url = extract_auth('http://example.com', f)
49
        self.assertEquals('http://example.com', url)
50
        self.assertEquals(0, len(f.credentials))
1185.50.94 by John Arbash Meinel
Updated web page url to http://bazaar-vcs.org
51
        url = extract_auth('http://user:pass@www.bazaar-vcs.org/bzr/bzr.dev', f)
52
        self.assertEquals('http://www.bazaar-vcs.org/bzr/bzr.dev', url)
1185.40.20 by Robey Pointer
allow user:pass@ info in http urls to be used for auth; this should be easily expandable later to use auth config files
53
        self.assertEquals(1, len(f.credentials))
1185.50.94 by John Arbash Meinel
Updated web page url to http://bazaar-vcs.org
54
        self.assertEquals([None, 'www.bazaar-vcs.org', 'user', 'pass'], f.credentials[0])
1185.40.20 by Robey Pointer
allow user:pass@ info in http urls to be used for auth; this should be easily expandable later to use auth config files
55
        
1185.16.68 by Martin Pool
- http url fixes suggested by Robey Pointer, and tests
56
    def test_abs_url(self):
57
        """Construction of absolute http URLs"""
1185.50.94 by John Arbash Meinel
Updated web page url to http://bazaar-vcs.org
58
        t = HttpTransport_urllib('http://bazaar-vcs.org/bzr/bzr.dev/')
1185.16.68 by Martin Pool
- http url fixes suggested by Robey Pointer, and tests
59
        eq = self.assertEqualDiff
60
        eq(t.abspath('.'),
1185.50.94 by John Arbash Meinel
Updated web page url to http://bazaar-vcs.org
61
           'http://bazaar-vcs.org/bzr/bzr.dev')
1185.16.68 by Martin Pool
- http url fixes suggested by Robey Pointer, and tests
62
        eq(t.abspath('foo/bar'), 
1185.50.94 by John Arbash Meinel
Updated web page url to http://bazaar-vcs.org
63
           'http://bazaar-vcs.org/bzr/bzr.dev/foo/bar')
1185.16.68 by Martin Pool
- http url fixes suggested by Robey Pointer, and tests
64
        eq(t.abspath('.bzr'),
1185.50.94 by John Arbash Meinel
Updated web page url to http://bazaar-vcs.org
65
           'http://bazaar-vcs.org/bzr/bzr.dev/.bzr')
1185.16.68 by Martin Pool
- http url fixes suggested by Robey Pointer, and tests
66
        eq(t.abspath('.bzr/1//2/./3'),
1185.50.94 by John Arbash Meinel
Updated web page url to http://bazaar-vcs.org
67
           'http://bazaar-vcs.org/bzr/bzr.dev/.bzr/1/2/3')
1185.16.68 by Martin Pool
- http url fixes suggested by Robey Pointer, and tests
68
69
    def test_invalid_http_urls(self):
70
        """Trap invalid construction of urls"""
1185.50.94 by John Arbash Meinel
Updated web page url to http://bazaar-vcs.org
71
        t = HttpTransport_urllib('http://bazaar-vcs.org/bzr/bzr.dev/')
1185.16.68 by Martin Pool
- http url fixes suggested by Robey Pointer, and tests
72
        self.assertRaises(ValueError,
73
            t.abspath,
74
            '.bzr/')
75
        self.assertRaises(ValueError,
76
            t.abspath,
77
            '/.bzr')
78
79
    def test_http_root_urls(self):
80
        """Construction of URLs from server root"""
1540.3.26 by Martin Pool
[merge] bzr.dev; pycurl not updated for readv yet
81
        t = HttpTransport_urllib('http://bzr.ozlabs.org/')
1185.16.68 by Martin Pool
- http url fixes suggested by Robey Pointer, and tests
82
        eq = self.assertEqualDiff
83
        eq(t.abspath('.bzr/tree-version'),
84
           'http://bzr.ozlabs.org/.bzr/tree-version')
1553.1.2 by James Henstridge
Add a test to make sure the user-agent header is being sent correctly.
85
1540.3.24 by Martin Pool
Add new protocol 'http+pycurl' that always uses PyCurl.
86
    def test_http_impl_urls(self):
87
        """There are servers which ask for particular clients to connect"""
88
        try:
89
            from bzrlib.transport.http._pycurl import HttpServer_PyCurl
90
            server = HttpServer_PyCurl()
91
            try:
92
                server.setUp()
93
                url = server.get_url()
94
                self.assertTrue(url.startswith('http+pycurl://'))
95
            finally:
96
                server.tearDown()
1540.3.30 by Martin Pool
Fix up bogus-url tests for broken dns servers, and error imports
97
        except DependencyNotPresent:
1540.3.24 by Martin Pool
Add new protocol 'http+pycurl' that always uses PyCurl.
98
            raise TestSkipped('pycurl not present')
1553.1.2 by James Henstridge
Add a test to make sure the user-agent header is being sent correctly.
99
1786.1.8 by John Arbash Meinel
[merge] Johan Rydberg test updates
100
1540.3.33 by Martin Pool
Fix http tests that were failing to run tearDown when setup got a missing dependency
101
class TestHttpMixins(object):
102
103
    def _prep_tree(self):
104
        self.build_tree(['xxx', 'foo/', 'foo/bar'], line_endings='binary',
105
                        transport=self.get_transport())
1553.1.2 by James Henstridge
Add a test to make sure the user-agent header is being sent correctly.
106
107
    def test_http_has(self):
1185.50.84 by John Arbash Meinel
[merge] bzr.dev, cleanup conflicts, fixup http tests for new TestCase layout.
108
        server = self.get_readonly_server()
1540.3.15 by Martin Pool
[merge] large merge to sync with bzr.dev
109
        t = self._transport(server.get_url())
1553.1.2 by James Henstridge
Add a test to make sure the user-agent header is being sent correctly.
110
        self.assertEqual(t.has('foo/bar'), True)
1185.50.84 by John Arbash Meinel
[merge] bzr.dev, cleanup conflicts, fixup http tests for new TestCase layout.
111
        self.assertEqual(len(server.logs), 1)
1540.3.15 by Martin Pool
[merge] large merge to sync with bzr.dev
112
        self.assertContainsRe(server.logs[0], 
113
            r'"HEAD /foo/bar HTTP/1.." (200|302) - "-" "bzr/')
1553.1.5 by James Henstridge
Make HTTP transport has() method do HEAD requests, and update test to
114
1540.3.15 by Martin Pool
[merge] large merge to sync with bzr.dev
115
    def test_http_has_not_found(self):
116
        server = self.get_readonly_server()
117
        t = self._transport(server.get_url())
1553.1.5 by James Henstridge
Make HTTP transport has() method do HEAD requests, and update test to
118
        self.assertEqual(t.has('not-found'), False)
1540.3.15 by Martin Pool
[merge] large merge to sync with bzr.dev
119
        self.assertContainsRe(server.logs[1], 
120
            r'"HEAD /not-found HTTP/1.." 404 - "-" "bzr/')
1553.1.2 by James Henstridge
Add a test to make sure the user-agent header is being sent correctly.
121
122
    def test_http_get(self):
1185.50.84 by John Arbash Meinel
[merge] bzr.dev, cleanup conflicts, fixup http tests for new TestCase layout.
123
        server = self.get_readonly_server()
1540.3.15 by Martin Pool
[merge] large merge to sync with bzr.dev
124
        t = self._transport(server.get_url())
1553.1.2 by James Henstridge
Add a test to make sure the user-agent header is being sent correctly.
125
        fp = t.get('foo/bar')
126
        self.assertEqualDiff(
127
            fp.read(),
1553.1.3 by James Henstridge
Make bzrlib.transport.http.HttpServer output referer and user agent as in
128
            'contents of foo/bar\n')
1185.50.84 by John Arbash Meinel
[merge] bzr.dev, cleanup conflicts, fixup http tests for new TestCase layout.
129
        self.assertEqual(len(server.logs), 1)
1540.3.15 by Martin Pool
[merge] large merge to sync with bzr.dev
130
        self.assertTrue(server.logs[0].find(
131
            '"GET /foo/bar HTTP/1.1" 200 - "-" "bzr/%s' % bzrlib.__version__) > -1)
132
133
1540.3.33 by Martin Pool
Fix http tests that were failing to run tearDown when setup got a missing dependency
134
class TestHttpConnections_urllib(TestCaseWithWebserver, TestHttpMixins):
1786.1.8 by John Arbash Meinel
[merge] Johan Rydberg test updates
135
1540.3.33 by Martin Pool
Fix http tests that were failing to run tearDown when setup got a missing dependency
136
    _transport = HttpTransport_urllib
1540.3.15 by Martin Pool
[merge] large merge to sync with bzr.dev
137
138
    def setUp(self):
1540.3.33 by Martin Pool
Fix http tests that were failing to run tearDown when setup got a missing dependency
139
        TestCaseWithWebserver.setUp(self)
140
        self._prep_tree()
141
2000.2.2 by John Arbash Meinel
Update the urllib.has test.
142
    def test_has_on_bogus_host(self):
2004.1.1 by vila
Connection sharing, with redirection. without authentification.
143
        # Get a free address and don't 'accept' on it, so that we
144
        # can be sure there is no http handler there, but set a
145
        # reasonable timeout to not slow down tests too much.
146
        default_timeout = socket.getdefaulttimeout()
147
        try:
148
            socket.setdefaulttimeout(2)
149
            s = socket.socket()
150
            s.bind(('localhost', 0))
151
            t = self._transport('http://%s:%s/' % s.getsockname())
152
            self.assertRaises(ConnectionError, t.has, 'foo/bar')
153
        finally:
154
            socket.setdefaulttimeout(default_timeout)
155
1540.3.33 by Martin Pool
Fix http tests that were failing to run tearDown when setup got a missing dependency
156
157
158
class TestHttpConnections_pycurl(TestCaseWithWebserver, TestHttpMixins):
159
160
    def _get_pycurl_maybe(self):
1540.3.29 by Martin Pool
Prevent selftest failure when pycurl is not installed
161
        try:
162
            from bzrlib.transport.http._pycurl import PyCurlTransport
1612.1.1 by Martin Pool
Raise errors correctly on pycurl connection failure
163
            return PyCurlTransport
1540.3.30 by Martin Pool
Fix up bogus-url tests for broken dns servers, and error imports
164
        except DependencyNotPresent:
1540.3.29 by Martin Pool
Prevent selftest failure when pycurl is not installed
165
            raise TestSkipped('pycurl not present')
1540.3.15 by Martin Pool
[merge] large merge to sync with bzr.dev
166
1540.3.33 by Martin Pool
Fix http tests that were failing to run tearDown when setup got a missing dependency
167
    _transport = property(_get_pycurl_maybe)
168
169
    def setUp(self):
170
        TestCaseWithWebserver.setUp(self)
171
        self._prep_tree()
172
173
1540.3.23 by Martin Pool
Allow urls like http+pycurl://host/ to use a particular impl
174
175
class TestHttpTransportRegistration(TestCase):
176
    """Test registrations of various http implementations"""
177
178
    def test_http_registered(self):
179
        import bzrlib.transport.http._urllib
180
        from bzrlib.transport import get_transport
181
        # urlllib should always be present
182
        t = get_transport('http+urllib://bzr.google.com/')
183
        self.assertIsInstance(t, Transport)
1540.3.26 by Martin Pool
[merge] bzr.dev; pycurl not updated for readv yet
184
        self.assertIsInstance(t, bzrlib.transport.http._urllib.HttpTransport_urllib)
1786.1.23 by John Arbash Meinel
Move offset_to_http_ranges back onto HttpTransportBase, clarify tests.
185
186
187
class TestOffsets(TestCase):
1786.1.28 by John Arbash Meinel
Update and add tests for the HttpTransportBase.range_header
188
    """Test offsets_to_ranges method"""
1786.1.23 by John Arbash Meinel
Move offset_to_http_ranges back onto HttpTransportBase, clarify tests.
189
190
    def test_offsets_to_ranges_simple(self):
191
        to_range = HttpTransportBase.offsets_to_ranges
1786.1.39 by John Arbash Meinel
Remove the ability to read negative offsets from readv()
192
        ranges = to_range([(10, 1)])
1786.1.23 by John Arbash Meinel
Move offset_to_http_ranges back onto HttpTransportBase, clarify tests.
193
        self.assertEqual([[10, 10]], ranges)
1786.1.39 by John Arbash Meinel
Remove the ability to read negative offsets from readv()
194
195
        ranges = to_range([(0, 1), (1, 1)])
196
        self.assertEqual([[0, 1]], ranges)
197
198
        ranges = to_range([(1, 1), (0, 1)])
199
        self.assertEqual([[0, 1]], ranges)
1786.1.23 by John Arbash Meinel
Move offset_to_http_ranges back onto HttpTransportBase, clarify tests.
200
201
    def test_offset_to_ranges_overlapped(self):
202
        to_range = HttpTransportBase.offsets_to_ranges
203
1786.1.39 by John Arbash Meinel
Remove the ability to read negative offsets from readv()
204
        ranges = to_range([(10, 1), (20, 2), (22, 5)])
205
        self.assertEqual([[10, 10], [20, 26]], ranges)
206
207
        ranges = to_range([(10, 1), (11, 2), (22, 5)])
208
        self.assertEqual([[10, 12], [22, 26]], ranges)
1786.1.23 by John Arbash Meinel
Move offset_to_http_ranges back onto HttpTransportBase, clarify tests.
209
1786.1.28 by John Arbash Meinel
Update and add tests for the HttpTransportBase.range_header
210
211
class TestRangeHeader(TestCase):
212
    """Test range_header method"""
213
214
    def check_header(self, value, ranges=[], tail=0):
215
        range_header = HttpTransportBase.range_header
216
        self.assertEqual(value, range_header(ranges, tail))
217
218
    def test_range_header_single(self):
1786.1.36 by John Arbash Meinel
pycurl expects us to just set the range of bytes, not including bytes=
219
        self.check_header('0-9', ranges=[[0,9]])
220
        self.check_header('100-109', ranges=[[100,109]])
1786.1.28 by John Arbash Meinel
Update and add tests for the HttpTransportBase.range_header
221
222
    def test_range_header_tail(self):
1786.1.36 by John Arbash Meinel
pycurl expects us to just set the range of bytes, not including bytes=
223
        self.check_header('-10', tail=10)
224
        self.check_header('-50', tail=50)
1786.1.28 by John Arbash Meinel
Update and add tests for the HttpTransportBase.range_header
225
226
    def test_range_header_multi(self):
1786.1.36 by John Arbash Meinel
pycurl expects us to just set the range of bytes, not including bytes=
227
        self.check_header('0-9,100-200,300-5000',
1786.1.28 by John Arbash Meinel
Update and add tests for the HttpTransportBase.range_header
228
                          ranges=[(0,9), (100, 200), (300,5000)])
229
230
    def test_range_header_mixed(self):
1786.1.36 by John Arbash Meinel
pycurl expects us to just set the range of bytes, not including bytes=
231
        self.check_header('0-9,300-5000,-50',
1786.1.28 by John Arbash Meinel
Update and add tests for the HttpTransportBase.range_header
232
                          ranges=[(0,9), (300,5000)],
233
                          tail=50)