Steve Piercy
2017-08-15 a9e8ac2f8e0d123d31c64346d380f1af2f6780d4
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
.. _qtut_static_assets:
 
==========================================
13: CSS/JS/Images Files With Static Assets
==========================================
 
Of course the Web is more than just markup. You need static assets: CSS, JS,
and images. Let's point our web app at a directory where Pyramid will serve
some static assets.
 
Objectives
==========
 
- Publish a directory of static assets at a URL.
 
- Use Pyramid to help generate URLs to files in that directory.
 
 
Steps
=====
 
#. First we copy the results of the ``view_classes`` step:
 
   .. code-block:: bash
 
    $ cd ..; cp -r view_classes static_assets; cd static_assets
    $ $VENV/bin/pip install -e .
 
#. We add a call ``config.add_static_view`` in
   ``static_assets/tutorial/__init__.py``:
 
   .. literalinclude:: static_assets/tutorial/__init__.py
    :linenos:
 
#. We can add a CSS link in the ``<head>`` of our template at
   ``static_assets/tutorial/home.pt``:
 
   .. literalinclude:: static_assets/tutorial/home.pt
    :language: html
 
#. Add a CSS file at ``static_assets/tutorial/static/app.css``:
 
   .. literalinclude:: static_assets/tutorial/static/app.css
    :language: css
 
#. We add a functional test that asserts that the newly added static file is delivered:
 
   .. literalinclude:: static_assets/tutorial/tests.py
    :language: python
    :pyobject: TutorialFunctionalTests.test_css
    :lineno-match:
 
#. Now run the tests:
 
   .. code-block:: bash
 
    $ $VENV/bin/py.test tutorial/tests.py -q
    ....
    5 passed in 0.50 seconds
 
#. Run your Pyramid application with:
 
   .. code-block:: bash
 
    $ $VENV/bin/pserve development.ini --reload
 
#. Open http://localhost:6543/ in your browser and note the new font.
 
 
Analysis
========
 
We changed our WSGI application to map requests under
http://localhost:6543/static/ to files and directories inside a ``static``
directory inside our ``tutorial`` package. This directory contained
``app.css``.
 
We linked to the CSS in our template. We could have hard-coded this link to
``/static/app.css``. But what if the site is later moved under
``/somesite/static/``? Or perhaps the web developer changes the arrangement on
disk? Pyramid gives a helper that provides flexibility on URL generation:
 
.. code-block:: html
 
  ${request.static_url('tutorial:static/app.css')}
 
This matches the ``path='tutorial:static'`` in our ``config.add_static_view``
registration. By using ``request.static_url`` to generate the full URL to the
static assets, you both ensure you stay in sync with the configuration and gain
refactoring flexibility later.
 
 
Extra credit
============
 
#. There is also a ``request.static_path`` API.  How does this differ from 
   ``request.static_url``?
 
.. seealso:: :ref:`assets_chapter`,
   :ref:`preventing_http_caching`, and
   :ref:`influencing_http_caching`