]> git.ipfire.org Git - thirdparty/httpx.git/commitdiff
Use pycon for Python console code blocks (#1187)
authorHugo van Kemenade <hugovk@users.noreply.github.com>
Tue, 18 Aug 2020 13:17:44 +0000 (16:17 +0300)
committerGitHub <noreply@github.com>
Tue, 18 Aug 2020 13:17:44 +0000 (15:17 +0200)
Co-authored-by: Florimond Manca <florimond.manca@gmail.com>
README.md
docs/advanced.md
docs/api.md
docs/async.md
docs/index.md
docs/quickstart.md

index 6f90f674a3a4089f9ea3bd695cc702bd808bc96c..d640e8574118c08e78e602c512f22ba8f282c733 100644 (file)
--- a/README.md
+++ b/README.md
@@ -23,7 +23,7 @@ release, so that you're able to properly review [API changes between package upd
 
 Let's get started...
 
-```python
+```pycon
 >>> import httpx
 >>> r = httpx.get('https://www.example.org/')
 >>> r
@@ -40,7 +40,7 @@ Or, using the async API...
 
 _Use [IPython](https://ipython.readthedocs.io/en/stable/) or Python 3.8+ with `python -m asyncio` to try this code interactively._
 
-```python
+```pycon
 >>> import httpx
 >>> async with httpx.AsyncClient() as client:
 >>>     r = await client.get('https://www.example.org/')
index 7d16c94122e4514fb407cb0e62a3dc91e0226a70..d6215f3d7c9f4c830dee936f37b679ee210192fa 100644 (file)
@@ -56,7 +56,7 @@ finally:
 
 Once you have a `Client`, you can send requests using `.get()`, `.post()`, etc. For example:
 
-```python
+```pycon
 >>> with httpx.Client() as client:
 ...     r = client.get('https://example.com')
 ...
@@ -68,7 +68,7 @@ These methods accept the same arguments as `httpx.get()`, `httpx.post()`, etc. T
 
 For example, to send a request with custom headers:
 
-```python
+```pycon
 >>> with httpx.Client() as client:
 ...     headers = {'X-Custom': 'value'}
 ...     r = client.get('https://example.com', headers=headers)
@@ -83,7 +83,7 @@ Clients allow you to apply configuration to all outgoing requests by passing par
 
 For example, to apply a set of custom headers _on every request_:
 
-```python
+```pycon
 >>> url = 'http://httpbin.org/headers'
 >>> headers = {'user-agent': 'my-app/0.0.1'}
 >>> with httpx.Client(headers=headers) as client:
@@ -99,7 +99,7 @@ When a configuration option is provided at both the client-level and request-lev
 
 - For headers, query parameters and cookies, the values are combined together. For example:
 
-```python
+```pycon
 >>> headers = {'X-Auth': 'from-client'}
 >>> params = {'client_id': 'client1'}
 >>> with httpx.Client(headers=headers, params=params) as client:
@@ -117,7 +117,7 @@ URL('https://example.com?client_id=client1&request_id=request1')
 
 - For all other parameters, the request-level value takes priority. For example:
 
-```python
+```pycon
 >>> with httpx.Client(auth=('tom', 'mot123')) as client:
 ...     r = client.get('https://example.com', auth=('alice', 'ecila123'))
 ...
@@ -135,7 +135,7 @@ Additionally, `Client` accepts some configuration options that aren't available
 
 For example, `base_url` allows you to prepend an URL to all outgoing requests:
 
-```python
+```pycon
 >>> with httpx.Client(base_url='http://httpbin.org') as client:
 ...     r = client.get('/headers')
 ...
@@ -232,7 +232,7 @@ not defined, HTTPX tries to add auth into request's header from .netrc file.
     you should create a new client or restart the interpreter.
 
 As default `trust_env` is true. To set false:
-```python
+```pycon
 >>> httpx.get('https://example.org/', trust_env=False)
 ```
 
@@ -240,7 +240,7 @@ If `NETRC` environment is empty, HTTPX tries to use default files.
 (`~/.netrc`, `~/_netrc`)
 
 To change `NETRC` environment:
-```python
+```pycon
 >>> import os
 >>> os.environ["NETRC"] = "my_default_folder/.my_netrc"
 ```
@@ -572,7 +572,7 @@ As mentioned in the [quickstart](/quickstart#sending-multipart-file-uploads)
 multipart file encoding is available by passing a dictionary with the
 name of the payloads as keys and either tuple of elements or a file-like object or a string as values.
 
-```python
+```pycon
 >>> files = {'upload-file': ('report.xls', open('report.xls', 'rb'), 'application/vnd.ms-excel')}
 >>> r = httpx.post("https://httpbin.org/post", files=files)
 >>> print(r.text)
@@ -597,7 +597,7 @@ on the file name, with unknown file extensions defaulting to "application/octet-
 If the file name is explicitly set to `None` then HTTPX will not include a content-type
 MIME header field.
 
-```python
+```pycon
 >>> files = {'upload-file': (None, 'text content', 'text/plain')}
 >>> r = httpx.post("https://httpbin.org/post", files=files)
 >>> print(r.text)
@@ -620,7 +620,7 @@ You can also send multiple files in one go with a multiple file field form.
 To do that, pass a list of `(field, <file>)` items instead of a dictionary, allowing you to pass multiple items with the same `field`.
 For instance this request sends 2 files, `foo.png` and `bar.png` in one request on the `images` form field:
 
-```python
+```pycon
 >>> files = [('images', ('foo.png', open('foo.png', 'rb'), 'image/png')),
                       ('images', ('bar.png', open('bar.png', 'rb'), 'image/png'))]
 >>> r = httpx.post("https://httpbin.org/post", files=files)
@@ -742,7 +742,7 @@ r = httpx.get("https://example.org", verify="path/to/client.pem")
 
 Alternatively, you can pass a standard library `ssl.SSLContext`.
 
-```python
+```pycon
 >>> import ssl
 >>> import httpx
 >>> context = ssl.create_default_context()
@@ -753,7 +753,7 @@ Alternatively, you can pass a standard library `ssl.SSLContext`.
 
 We also include a helper function for creating properly configured `SSLContext` instances.
 
-```python
+```pycon
 >>> context = httpx.create_ssl_context()
 ```
 
@@ -761,7 +761,7 @@ The `create_ssl_context` function accepts the same set of SSL configuration argu
 (`trust_env`, `verify`, `cert` and `http2` arguments)
 as `httpx.Client` or `httpx.AsyncClient`
 
-```python
+```pycon
 >>> import httpx
 >>> context = httpx.create_ssl_context(verify="/tmp/client.pem")
 >>> httpx.get('https://example.org', verify=context)
@@ -796,7 +796,7 @@ If you do need to make HTTPS connections to a local server, for example to test
 1. Pass the server key/cert files when starting your local server. (This depends on the particular web server you're using. For example, [Uvicorn](https://www.uvicorn.org) provides the `--ssl-keyfile` and `--ssl-certfile` options.)
 1. Tell HTTPX to use the certificates stored in `client.pem`:
 
-```python
+```pycon
 >>> import httpx
 >>> r = httpx.get("https://localhost:8000", verify="/tmp/client.pem")
 >>> r
@@ -814,7 +814,7 @@ class directly, and pass it to the client instance. The `httpcore` package
 provides a `local_address` configuration that is only available via this
 low-level API.
 
-```python
+```pycon
 >>> import httpx, httpcore
 >>> ssl_context = httpx.create_ssl_context()
 >>> transport = httpcore.SyncConnectionPool(
@@ -854,7 +854,7 @@ HTTPX also currently ships with a transport that uses the excellent
 [`urllib3` library](https://urllib3.readthedocs.io/en/latest/), which can be
 used with the sync `Client`...
 
-```python
+```pycon
 >>> import httpx
 >>> client = httpx.Client(transport=httpx.URLLib3Transport())
 >>> client.get("https://example.org")
@@ -891,7 +891,7 @@ class HelloWorldTransport(httpcore.SyncHTTPTransport):
 
 Which we can use in the same way:
 
-```python
+```pycon
 >>> import httpx
 >>> client = httpx.Client(transport=HelloWorldTransport())
 >>> response = client.get("https://example.org/")
index e04e5696041dfc0143fca1188b19b9241d76d0a4..db57f3e7ac10ecdc8bf2636b3284ff26b6b42bc7 100644 (file)
@@ -88,7 +88,7 @@
 *An HTTP request. Can be constructed explicitly for more control over exactly
 what gets sent over the wire.*
 
-```python
+```pycon
 >>> request = httpx.Request("GET", "https://example.org", headers={'host': 'example.org'})
 >>> response = client.send(request)
 ```
@@ -104,7 +104,7 @@ what gets sent over the wire.*
 
 *A normalized, IDNA supporting URL.*
 
-```python
+```pycon
 >>> url = URL("https://example.org/")
 >>> url.host
 'example.org'
@@ -128,7 +128,7 @@ what gets sent over the wire.*
 
 *A case-insensitive multi-dict.*
 
-```python
+```pycon
 >>> headers = Headers({'Content-Type': 'application/json'})
 >>> headers['content-type']
 'application/json'
@@ -141,7 +141,7 @@ what gets sent over the wire.*
 
 *A dict-like cookie store.*
 
-```python
+```pycon
 >>> cookies = Cookies()
 >>> cookies.set("name", "value", domain="example.org")
 ```
index a6a3c06bfe393b471ef7931a0cf74d8dccb18058..ba6c6ad70468830b1cf4db1b849d9e0a18108c8d 100644 (file)
@@ -14,7 +14,7 @@ async client for sending outgoing HTTP requests.
 
 To make asynchronous requests, you'll need an `AsyncClient`.
 
-```python
+```pycon
 >>> async with httpx.AsyncClient() as client:
 >>>     r = await client.get('https://www.example.com/')
 >>> r
@@ -64,7 +64,7 @@ await client.aclose()
 
 The `AsyncClient.stream(method, url, ...)` method is an async context block.
 
-```python
+```pycon
 >>> client = httpx.AsyncClient()
 >>> async with client.stream('GET', 'https://www.example.com/') as response:
 >>>     async for chunk in response.aiter_bytes():
@@ -177,7 +177,7 @@ app = Starlette(routes=[Route("/", hello)])
 
 We can make requests directly against the application, like so:
 
-```python
+```pycon
 >>> import httpx
 >>> async with httpx.AsyncClient(app=app, base_url="http://testserver") as client:
 ...     r = await client.get("/")
index 9ab5760bec4b894dd77280979d5c8fae90677db8..12ba351b07e0ef764084334fd4d85525a1b275cc 100644 (file)
@@ -35,7 +35,7 @@ HTTPX is a fully featured HTTP client for Python 3, which provides sync and asyn
 
 Let's get started...
 
-```python
+```pycon
 >>> import httpx
 >>> r = httpx.get('https://www.example.org/')
 >>> r
@@ -52,7 +52,7 @@ Or, using the async API...
 
 _Use [IPython](https://ipython.readthedocs.io/en/stable/) or Python 3.8+ with `python -m asyncio` to try this code interactively._
 
-```python
+```pycon
 >>> import httpx
 >>> async with httpx.AsyncClient() as client:
 >>>     r = await client.get('https://www.example.org/')
index f19421558f3de548a153e876775d6e8fd841e9ad..f11f7a45dacdc90340de8027000b8c32b8320b78 100644 (file)
@@ -2,13 +2,13 @@
 
 First, start by importing HTTPX:
 
-```python
+```pycon
 >>> import httpx
 ```
 
 Now, let’s try to get a webpage.
 
-```python
+```pycon
 >>> r = httpx.get('https://httpbin.org/get')
 >>> r
 <Response [200 OK]>
@@ -16,13 +16,13 @@ Now, let’s try to get a webpage.
 
 Similarly, to make an HTTP POST request:
 
-```python
+```pycon
 >>> r = httpx.post('https://httpbin.org/post', data={'key': 'value'})
 ```
 
 The PUT, DELETE, HEAD, and OPTIONS requests all follow the same style:
 
-```python
+```pycon
 >>> r = httpx.put('https://httpbin.org/put', data={'key': 'value'})
 >>> r = httpx.delete('https://httpbin.org/delete')
 >>> r = httpx.head('https://httpbin.org/get')
@@ -33,7 +33,7 @@ The PUT, DELETE, HEAD, and OPTIONS requests all follow the same style:
 
 To include URL query parameters in the request, use the `params` keyword:
 
-```python
+```pycon
 >>> params = {'key1': 'value1', 'key2': 'value2'}
 >>> r = httpx.get('https://httpbin.org/get', params=params)
 ```
@@ -41,14 +41,14 @@ To include URL query parameters in the request, use the `params` keyword:
 To see how the values get encoding into the URL string, we can inspect the
 resulting URL that was used to make the request:
 
-```python
+```pycon
 >>> r.url
 URL('https://httpbin.org/get?key2=value2&key1=value1')
 ```
 
 You can also pass a list of items as a value:
 
-```python
+```pycon
 >>> params = {'key1': 'value1', 'key2': ['value2', 'value3']}
 >>> r = httpx.get('https://httpbin.org/get', params=params)
 >>> r.url
@@ -59,7 +59,7 @@ URL('https://httpbin.org/get?key1=value1&key2=value2&key2=value3')
 
 HTTPX will automatically handle decoding the response content into Unicode text.
 
-```python
+```pycon
 >>> r = httpx.get('https://www.example.org/')
 >>> r.text
 '<!doctype html>\n<html>\n<head>\n<title>Example Domain</title>...'
@@ -67,7 +67,7 @@ HTTPX will automatically handle decoding the response content into Unicode text.
 
 You can inspect what encoding has been used to decode the response.
 
-```python
+```pycon
 >>> r.encoding
 'UTF-8'
 ```
@@ -75,7 +75,7 @@ You can inspect what encoding has been used to decode the response.
 If you need to override the standard behavior and explicitly set the encoding to
 use, then you can do that too.
 
-```python
+```pycon
 >>> r.encoding = 'ISO-8859-1'
 ```
 
@@ -83,7 +83,7 @@ use, then you can do that too.
 
 The response content can also be accessed as bytes, for non-text responses:
 
-```python
+```pycon
 >>> r.content
 b'<!doctype html>\n<html>\n<head>\n<title>Example Domain</title>...'
 ```
@@ -94,7 +94,7 @@ encoding will also be supported.
 
 For example, to create an image from binary data returned by a request, you can use the following code:
 
-```python
+```pycon
 >>> from PIL import Image
 >>> from io import BytesIO
 >>> i = Image.open(BytesIO(r.content))
@@ -104,7 +104,7 @@ For example, to create an image from binary data returned by a request, you can
 
 Often Web API responses will be encoded as JSON.
 
-```python
+```pycon
 >>> r = httpx.get('https://api.github.com/events')
 >>> r.json()
 [{u'repository': {u'open_issues': 0, u'url': 'https://github.com/...' ...  }}]
@@ -114,7 +114,7 @@ Often Web API responses will be encoded as JSON.
 
 To include additional headers in the outgoing request, use the `headers` keyword argument:
 
-```python
+```pycon
 >>> url = 'http://httpbin.org/headers'
 >>> headers = {'user-agent': 'my-app/0.0.1'}
 >>> r = httpx.get(url, headers=headers)
@@ -126,7 +126,7 @@ Some types of HTTP requests, such as `POST` and `PUT` requests, can include data
 in the request body. One common way of including that is as form-encoded data,
 which is used for HTML forms.
 
-```python
+```pycon
 >>> data = {'key1': 'value1', 'key2': 'value2'}
 >>> r = httpx.post("https://httpbin.org/post", data=data)
 >>> print(r.text)
@@ -142,7 +142,7 @@ which is used for HTML forms.
 
 Form encoded data can also include multiple values from a given key.
 
-```python
+```pycon
 >>> data = {'key1': ['value1', 'value2']}
 >>> r = httpx.post("https://httpbin.org/post", data=data)
 >>> print(r.text)
@@ -162,7 +162,7 @@ Form encoded data can also include multiple values from a given key.
 
 You can also upload files, using HTTP multipart encoding:
 
-```python
+```pycon
 >>> files = {'upload-file': open('report.xls', 'rb')}
 >>> r = httpx.post("https://httpbin.org/post", files=files)
 >>> print(r.text)
@@ -178,7 +178,7 @@ You can also upload files, using HTTP multipart encoding:
 You can also explicitly set the filename and content type, by using a tuple
 of items for the file value:
 
-```python
+```pycon
 >>> files = {'upload-file': ('report.xls', open('report.xls', 'rb'), 'application/vnd.ms-excel')}
 >>> r = httpx.post("https://httpbin.org/post", files=files)
 >>> print(r.text)
@@ -193,7 +193,7 @@ of items for the file value:
 
 If you need to include non-file data fields in the multipart form, use the `data=...` parameter:
 
-```python
+```pycon
 >>> data = {'message': 'Hello, world!'}
 >>> files = {'file': open('report.xls', 'rb')}
 >>> r = httpx.post("https://httpbin.org/post", data=data, files=files)
@@ -215,7 +215,7 @@ If you need to include non-file data fields in the multipart form, use the `data
 Form encoded data is okay if all you need is a simple key-value data structure.
 For more complicated data structures you'll often want to use JSON encoding instead.
 
-```python
+```pycon
 >>> data = {'integer': 123, 'boolean': True, 'list': ['a', 'b', 'c']}
 >>> r = httpx.post("https://httpbin.org/post", json=data)
 >>> print(r.text)
@@ -246,7 +246,7 @@ binary data.
 
 We can inspect the HTTP status code of the response:
 
-```python
+```pycon
 >>> r = httpx.get('https://httpbin.org/get')
 >>> r.status_code
 200
@@ -254,14 +254,14 @@ We can inspect the HTTP status code of the response:
 
 HTTPX also includes an easy shortcut for accessing status codes by their text phrase.
 
-```python
+```pycon
 >>> r.status_code == httpx.codes.OK
 True
 ```
 
 We can raise an exception for any Client or Server error responses (4xx or 5xx status codes):
 
-```python
+```pycon
 >>> not_found = httpx.get('https://httpbin.org/status/404')
 >>> not_found.status_code
 404
@@ -275,7 +275,7 @@ For more information check: https://httpstatuses.com/404
 
 Any successful response codes will simply return `None` rather than raising an exception.
 
-```python
+```pycon
 >>> r.raise_for_status()
 ```
 
@@ -283,7 +283,7 @@ Any successful response codes will simply return `None` rather than raising an e
 
 The response headers are available as a dictionary-like interface.
 
-```python
+```pycon
 >>> r.headers
 Headers({
     'content-encoding': 'gzip',
@@ -298,7 +298,7 @@ Headers({
 
 The `Headers` data type is case-insensitive, so you can use any capitalization.
 
-```python
+```pycon
 >>> r.headers['Content-Type']
 'application/json'
 
@@ -316,7 +316,7 @@ For large downloads you may want to use streaming responses that do not load the
 
 You can stream the binary content of the response...
 
-```python
+```pycon
 >>> with httpx.stream("GET", "https://www.example.com") as r:
 ...     for data in r.iter_bytes():
 ...         print(data)
@@ -324,7 +324,7 @@ You can stream the binary content of the response...
 
 Or the text of the response...
 
-```python
+```pycon
 >>> with httpx.stream("GET", "https://www.example.com") as r:
 ...     for text in r.iter_text():
 ...         print(text)
@@ -332,7 +332,7 @@ Or the text of the response...
 
 Or stream the text, on a line-by-line basis...
 
-```python
+```pycon
 >>> with httpx.stream("GET", "https://www.example.com") as r:
 ...     for line in r.iter_lines():
 ...         print(line)
@@ -342,7 +342,7 @@ HTTPX will use universal line endings, normalising all cases to `\n`.
 
 In some cases you might want to access the raw bytes on the response without applying any HTTP content decoding. In this case any content encoding that the web server has applied such as `gzip`, `deflate`, or `brotli` will not be automatically decoded.
 
-```python
+```pycon
 >>> with httpx.stream("GET", "https://www.example.com") as r:
 ...     for chunk in r.iter_raw():
 ...         print(chunk)
@@ -350,7 +350,7 @@ In some cases you might want to access the raw bytes on the response without app
 
 If you're using streaming responses in any of these ways then the `response.content` and `response.text` attributes will not be available, and will raise errors if accessed. However you can also use the response streaming functionality to conditionally load the response body:
 
-```python
+```pycon
 >>> with httpx.stream("GET", "https://www.example.com") as r:
 ...     if r.headers['Content-Length'] < TOO_LONG:
 ...         r.read()
@@ -361,7 +361,7 @@ If you're using streaming responses in any of these ways then the `response.cont
 
 Any cookies that are set on the response can be easily accessed:
 
-```python
+```pycon
 >>> r = httpx.get('http://httpbin.org/cookies/set?chocolate=chip', allow_redirects=False)
 >>> r.cookies['chocolate']
 'chip'
@@ -369,7 +369,7 @@ Any cookies that are set on the response can be easily accessed:
 
 To include cookies in an outgoing request, use the `cookies` parameter:
 
-```python
+```pycon
 >>> cookies = {"peanut": "butter"}
 >>> r = httpx.get('http://httpbin.org/cookies', cookies=cookies)
 >>> r.json()
@@ -379,7 +379,7 @@ To include cookies in an outgoing request, use the `cookies` parameter:
 Cookies are returned in a `Cookies` instance, which is a dict-like data structure
 with additional API for accessing cookies by their domain or path.
 
-```python
+```pycon
 >>> cookies = httpx.Cookies()
 >>> cookies.set('cookie_on_domain', 'hello, there!', domain='httpbin.org')
 >>> cookies.set('cookie_off_domain', 'nope.', domain='example.org')
@@ -398,7 +398,7 @@ in which they were made.
 
 For example, GitHub redirects all HTTP requests to HTTPS.
 
-```python
+```pycon
 >>> r = httpx.get('http://github.com/')
 >>> r.url
 URL('https://github.com/')
@@ -410,7 +410,7 @@ URL('https://github.com/')
 
 You can modify the default redirection handling with the allow_redirects parameter:
 
-```python
+```pycon
 >>> r = httpx.get('http://github.com/', allow_redirects=False)
 >>> r.status_code
 301
@@ -420,7 +420,7 @@ You can modify the default redirection handling with the allow_redirects paramet
 
 If you’re making a `HEAD` request, you can use this to enable redirection:
 
-```python
+```pycon
 >>> r = httpx.head('http://github.com/', allow_redirects=True)
 >>> r.url
 'https://github.com/'
@@ -437,13 +437,13 @@ raise an error rather than hanging indefinitely.
 The default timeout for network inactivity is five seconds. You can modify the
 value to be more or less strict:
 
-```python
+```pycon
 >>> httpx.get('https://github.com/', timeout=0.001)
 ```
 
 You can also disable the timeout behavior completely...
 
-```python
+```pycon
 >>> httpx.get('https://github.com/', timeout=None)
 ```
 
@@ -457,7 +457,7 @@ To provide Basic authentication credentials, pass a 2-tuple of
 plaintext `str` or `bytes` objects as the `auth` argument to the request
 functions:
 
-```python
+```pycon
 >>> httpx.get("https://example.com", auth=("my_user", "password123"))
 ```
 
@@ -466,7 +466,7 @@ a `DigestAuth` object with the plaintext username and password as arguments.
 This object can be then passed as the `auth` argument to the request methods
 as above:
 
-```python
+```pycon
 >>> auth = httpx.DigestAuth("my_user", "password123")
 >>> httpx.get("https://example.com", auth=auth)
 <Response [200 OK]>