File: developing.rst

package info (click to toggle)
quart 0.20.0-2
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid
  • size: 1,888 kB
  • sloc: python: 8,644; makefile: 42; sh: 17; sql: 6
file content (119 lines) | stat: -rw-r--r-- 2,881 bytes parent folder | download | duplicates (2)
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
108
109
110
111
112
113
114
115
116
117
118
119
.. _developing:

Developing with Quart
=====================

When developing it is best to have your Quart app running so you can
test any changes you make directly. This is made easier by the
reloader which reloads your app whenever a file is changed. The
reloader is active if you use ``app.run()``, ``quart run`` command or
``run_task`` method.


Quart run
---------

The ``quart run`` command is the recommended way to develop with Quart
and will run whichever app is specified by the ``QUART_APP``
environment variable. For example,

.. code-block:: python
    :caption: run.py

    from quart import Quart

    app = Quart(__name__)

    ...

.. code-block:: console

    $ QUART_APP=run:app quart run

The ``quart run`` command comes with ``--host``, and ``--port`` to
specify where the app is served, and ``--certfile`` and ``--keyfile``
to specify the SSL certificates to use.

app.run()
---------

The Quart class, instances typically named ``app``, has a
:meth:`~quart.Quart.run` method. This method runs a development server,
automatically turning on debug mode and code reloading. This can be
used to run the app via this snippet,

.. code-block:: python
    :caption: run.py

    from quart import Quart

    app = Quart(__name__)

    ...

    if __name__ == "__main__":
        app.run()

with the ``if`` ensuring that this code only runs if the file is run
directly, i.e.

.. code-block:: console

    $ python run.py

which ensures that it doesn't run in production.

The :meth:`~quart.Quart.run` method has options to set the ``host``,
and ``port`` the app will be served over, to turn off the reloader via
``use_reloader=False``, and to add specify SSL certificates via the
``certfile`` and ``keyfile`` options.

.. note::

   The :meth:`~quart.Quart.run` method will create a new event loop,
   use ``run_task`` instead if you wish to control the event loop.

app.run_task
------------

The Quart class also has a :meth:`~quart.Quart.run_task` method with
the same options as the :meth:`~quart.Quart.run` method. The
``run_task`` returns an asyncio task that when awaited will run the
app. This is as useful as it makes no alterations to the event
loop. The ``run_task`` can be used as so,

.. code-block:: python
    :caption: run.py

    import asyncio

    from quart import Quart

    app = Quart(__name__)

    ...

    if __name__ == "__main__":
        asyncio.run(app.run_task())

with the ``if`` ensuring that this code only runs if the file is run
directly, i.e.

.. code-block:: console

    $ python run.py

which ensures that it doesn't run in production.


Curl
----

To test the app locally I like to use a web browser, and the curl
command line tool. I'd recommend reading the curl `documentation
<https://curl.se/docs/>`_ and always using the ``-v``, ``--verbose``
option. For example,

.. code-block:: console

    $ curl -v localhost:5000/