File: 1.1.0.rst

package info (click to toggle)
python-falcon 3.1.1-5
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid, trixie
  • size: 5,204 kB
  • sloc: python: 28,455; makefile: 184; sh: 139; javascript: 66
file content (107 lines) | stat: -rw-r--r-- 5,257 bytes parent folder | download | duplicates (4)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
Changelog for Falcon 1.1.0
==========================

Breaking Changes
----------------

(None)

New & Improved
--------------

- A new `bounded_stream` property was added to :class:`falcon.Request`
  that can be used in place of the `stream` property to mitigate
  the blocking behavior of input objects used by some WSGI servers.
- A new `uri_template` property was added to :class:`~falcon.Request`
  to expose the template for the route corresponding to the
  path requested by the user agent.
- A `context` property was added to :class:`~falcon.Response` to mirror
  the same property that is already available for
  :class:`~falcon.Request`.
- JSON-encoded query parameter values can now be retrieved and decoded
  in a single step via :meth:`~falcon.Request.get_param_as_dict`.
- CSV-style parsing of query parameter values can now be disabled.
- :meth:`~falcon.Request.get_param_as_bool` now recognizes "on" and
  "off" in support of IE's default checkbox values.
- An `accept_ranges` property was added to :class:`~falcon.Response` to
  facilitate setting the Accept-Ranges header.
- Added the :class:`~falcon.HTTPUriTooLong` and
  :class:`~falcon.HTTPGone` error classes.
- When a title is not specified for :class:`~falcon.HTTPError`, it now
  defaults to the HTTP status text.
- All parameters are now optional for most error classes.
- Cookie-related documentation has been clarified and expanded
- The :class:`falcon.testing.Cookie` class was added to represent a
  cookie returned by a simulated request. :class:`falcon.testing.Result`
  now exposes a `cookies` attribute for examining returned cookies.
- pytest support was added to Falcon's testing framework. Apps can now
  choose to either write unittest- or pytest-style tests.
- The test runner for Falcon's own tests was switched from nose
  to pytest.
- When simulating a request using Falcon's testing framework, query
  string parameters can now be specified as a :class:`dict`, as
  an alternative to passing a raw query string.
- A flag is now passed to the `process_request` middleware method to
  signal whether or not an exception was raised while processing the
  request. A shim was added to avoid breaking existing middleware
  methods that do not yet accept this new parameter.
- A new CLI utility, `falcon-print-routes`, was added that takes in a
  module:callable, introspects the routes, and prints the
  results to stdout. This utility is automatically installed along
  with the framework::

    $ falcon-print-routes commissaire:api
    -> /api/v0/status
    -> /api/v0/cluster/{name}
    -> /api/v0/cluster/{name}/hosts
    -> /api/v0/cluster/{name}/hosts/{address}

- Custom attributes can now be attached to instances of
  :class:`~falcon.Request` and :class:`~falcon.Response`. This can be
  used as an alternative to adding values to the `context` property,
  or implementing custom subclasses.
- :meth:`~falcon.get_http_status` was implemented to provide a way to
  look up a full HTTP status line, given just a status code.

Fixed
-----

- When :any:`auto_parse_form_urlencoded` is
  set to ``True``, the framework now checks the HTTP method before
  attempting to consume and parse the body.
- Before attempting to read the body of a form-encoded request, the
  framework now checks the Content-Length header to ensure that a
  non-empty body is expected. This helps prevent bad requests from
  causing a blocking read when running behind certain WSGI servers.
- When the requested method is not implemented for the target resource,
  the framework now raises :class:`~falcon.HTTPMethodNotAllowed`, rather
  than modifying the :class:`~falcon.Request` object directly. This
  improves visibility for custom error handlers and for middleware
  methods.
- Error class docstrings have been updated to reflect the latest RFCs.
- When an error is raised by a resource method or a hook, the error
  will now always be processed (including setting the appropriate
  properties of the :class:`~falcon.Response` object) before middleware
  methods are called.
- A case was fixed in which middleware processing did not
  continue when an instance of :class:`~falcon.HTTPError` or
  :class:`~falcon.HTTPStatus` was raised.
- The :meth:`~falcon.uri.encode` method will now attempt to detect
  whether the specified string has already been encoded, and return
  it unchanged if that is the case.
- The default OPTIONS responder now explicitly sets Content-Length
  to zero in the response.
- :class:`falcon.testing.Result` now assumes that the response body
  is encoded as UTF-8 when the character set is not specified, rather
  than raising an error when attempting to decode the response body.
- When simulating requests, Falcon's testing framework now properly
  tunnels Unicode characters through the WSGI interface.
- ``import falcon.uri`` now works, in addition to
  ``from falcon import uri``.
- URI template fields are now validated up front, when the route is
  added, to ensure they are valid Python identifiers. This prevents
  cryptic errors from being raised later on when requests are routed.
- When running under Python 3, :meth:`inspect.signature()` is used
  instead of :meth:`inspect.getargspec()` to provide compatibility with
  annotated functions.