Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Mention, and emphasise, HTTPClient #276

Merged
merged 13 commits into from
Mar 26, 2020
Merged
Show file tree
Hide file tree
Changes from 11 commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
1 change: 1 addition & 0 deletions changelog.d/276.doc.rst
Original file line number Diff line number Diff line change
@@ -0,0 +1 @@
The treq documentation has been revised to emphasize use of `treq.client.HTTPClient` over the module-level convenience functions in the `treq` module.
15 changes: 11 additions & 4 deletions docs/api.rst
Original file line number Diff line number Diff line change
Expand Up @@ -6,6 +6,11 @@ This page lists all of the interfaces exposed by the `treq` package.
Making Requests
---------------

The :py:mod:`treq` module provides several shortcut functions for making
Copy link

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Would "convenience" be a better word here (and below) than "shortcut"?

Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Sure, that makes sense to me.

requests. These functions all create a default
:py:class:`treq.client.HTTPClient` instance and pass their arguments to
the appropriate :py:class:`~treq.client.HTTPClient` method.

.. module:: treq

.. autofunction:: request
Expand All @@ -24,14 +29,14 @@ Accessing Content
.. autofunction:: text_content
.. autofunction:: json_content

HTTPClient Objects
------------------
The HTTP Client
===============

.. module:: treq.client

The :class:`treq.client.HTTPClient` class provides the same interface as the :mod:`treq` module itself.
:class:`treq.client.HTTPClient` has methods that match the signatures of the shortcut request functions in the :mod:`treq` module.

.. autoclass:: HTTPClient
.. autoclass:: HTTPClient(agent, cookiejar=None, data_to_body_producer=IBodyProducer)

.. automethod:: request
.. automethod:: get
Expand Down Expand Up @@ -79,6 +84,8 @@ Augmented Response Objects
Test Helpers
------------

.. module:: treq.testing

The :mod:`treq.testing` module contains tools for in-memory testing of HTTP clients and servers.

StubTreq Objects
Expand Down
19 changes: 19 additions & 0 deletions docs/examples/custom_agent.py
Original file line number Diff line number Diff line change
@@ -0,0 +1,19 @@
from treq.client import HTTPClient
from _utils import print_response
from twisted.internet.task import react
from twisted.web.client import Agent

def make_custom_agent(reactor):
return Agent(reactor, connectTimeout=42)

def main(reactor, *args):
agent = make_custom_agent(reactor)
http_client = HTTPClient(agent)
d = http_client.get(
'https://secure.example.net/area51',
auth=('admin', "you'll never guess!"))
d.addCallback(print_response)
return d

react(main, [])

38 changes: 17 additions & 21 deletions docs/howto.rst
Original file line number Diff line number Diff line change
Expand Up @@ -24,7 +24,7 @@ Full example: :download:`download_file.py <examples/download_file.py>`
Query Parameters
----------------

:py:func:`treq.request` supports a ``params`` keyword argument which will
:py:func:`treq.HTTPClient.request` supports a ``params`` keyword argument which will
be URL-encoded and added to the ``url`` argument in addition to any query
parameters that may already exist.

Expand Down Expand Up @@ -91,7 +91,7 @@ Cookies

Cookies can be set by passing a ``dict`` or ``cookielib.CookieJar`` instance
via the ``cookies`` keyword argument. Later cookies set by the server can be
retrieved using the :py:meth:`~treq.response._Response.cookies()` method.
retrieved using the :py:meth:`~treq.response._Response.cookies()` method of the response.

The object returned by :py:meth:`~treq.response._Response.cookies()` supports the same key/value
access as `requests cookies <https://requests.readthedocs.io/en/latest/user/quickstart/#cookies>`_.
Expand All @@ -102,25 +102,21 @@ access as `requests cookies <https://requests.readthedocs.io/en/latest/user/quic

Full example: :download:`using_cookies.py <examples/using_cookies.py>`

Agent Customization
-------------------
Customizing the Twisted Agent
-----------------------------

treq creates its own `twisted.web.client.Agent
<https://twistedmatrix.com/documents/current/api/twisted.web.client.Agent.html>`_
with reasonable defaults, but you may want to provide your own custom agent.
A custom agent can be passed to the various treq request methods using the
``agent`` keyword argument.
The main :py:mod:`treq` module has helper functions that automatically instantiate
an instance of :py:class:`treq.client.HTTPClient`. You can create an instance
of :py:class:`~treq.client.HTTPClient` directly in order to customize the
paramaters used to initialize it.
Internally, the :py:class:`~treq.client.HTTPClient` wraps an instance of
:py:class:`twisted.web.client.Agent`. When you create an instance of
:py:class:`~treq.client.HTTPClient`, you must initialize it with an instance of
:py:class:`~twisted.web.client.Agent`. This allows you to customize its
behavior.

.. code-block:: python

custom_agent = Agent(reactor, connectTimeout=42)
treq.get(url, agent=custom_agent)

Additionally a custom client can be instantiated to use a custom agent
using the ``agent`` keyword argument:

.. code-block:: python
.. literalinclude:: examples/custom_agent.py
:linenos:
:lines: 6-19

custom_agent = Agent(reactor, connectTimeout=42)
client = treq.client.HTTPClient(agent=custom_agent)
client.get(url)
Full example: :download:`custom_agent.py <examples/custom_agent.py>`