Makefile¶
pyramid_oereb
uses GNU-Makefile a lot to setup itself and its components. This section is a try to
describe the structure of the used
Makefile.
A Makefile is constructed of so called targets. Most often a target represents a file which should be
created. So you the line defines
the commands how to create the development.ini file which is necessary to run DEV instance of
pyramid_oereb
.
To stay with this line in the Makefile you can see that a mako-render command is called with several variables
from a virtual environment
. Thats a bit interesting. More interesting is the dependency which is defined
right on the same line of the target: install
It refers to the install
target
some lines above which has a
dependency requirements-timestamp
which refers to a target
some lines above … and so forth.
Important to know is that GNU Make keeps track of target files. So if some change was made for instance to
your requirements.txt
file to update a pypi package a simple make build
is enough to setup your project
with it and provide it in your VENV. If you call make build
for another reason and say the
requirements.txt
file was not touched by you the complete targets which depend on this file are omitted.
This is a really powerful tool which - used correctly - can save a lot of work compared to write the same logic in a shell scripte or in a python script. In the best case it leads to reproducible environments independent of the machine it is issued on.
However, because it is a bit different how it works, people often struggle with its usage and avoid to use it at all.
The following sections should help you to understand better what the Makefile provides you when you call a decent target. It shows the dependency-target-system in a graph.
green elements are files which are expected to be there (e.g.
setup.py
)red elements are files which will be created through the target or which are meta targets (“phony” - no files are created)
General targets¶
make install
¶
Basically sets up your virtual environment based on the projects requirements.
data:image/s3,"s3://crabby-images/eb176/eb17684eae4d9d2464300808f61654857a87d2e4" alt="_images/make.install.png"
make build
¶
Completely sets up your application to be ready for running. This includes steps like:
prepare
development.ini
fileprepare DEV DB
fill DEV DB
…
data:image/s3,"s3://crabby-images/a5570/a5570ceb122964b5100419b8978d0fc0de9548f8" alt="_images/make.build.png"
Run a development server¶
make serve-dev
¶
Runs a pserve
development server which reloads when changes to python source files were made.
data:image/s3,"s3://crabby-images/351bf/351bf991ab7d8dda90c2472901b83e938e1537d8" alt="_images/make.serve-dev.png"
make serve
¶
Runs a pserve
development server.
data:image/s3,"s3://crabby-images/5efc4/5efc486776f3664da8f9bf4a3703d0efbef65454" alt="_images/make.serve.png"
Testing¶
make tests
¶
Executes all python testing. This includes the module tests (they can be executed directly to save time).
data:image/s3,"s3://crabby-images/b2e89/b2e89787bb359c9dd93eee7bb9c26ebc8e0a86ba" alt="_images/make.tests.png"
make lint
¶
Does the linting to check code style conformance.
data:image/s3,"s3://crabby-images/5a1f0/5a1f0c7a1df127fcfe684e78884aa83a7119983e" alt="_images/make.lint.png"
make git-attributes
¶
Executes the gitattributes checker.
data:image/s3,"s3://crabby-images/17a6f/17a6f8c28c1bb184e2895ac47788bdf61b939ec2" alt="_images/make.git-attributes.png"
make check
¶
Collection target to execute all targets mentioned above in one single call.
data:image/s3,"s3://crabby-images/a7e6b/a7e6b9fbca4a4a73ae2e4b6c5134b61aff059828" alt="_images/make.check.png"
Maintainence¶
make updates
¶
Provides a list of outdated python packages and the possible better target version.
data:image/s3,"s3://crabby-images/97869/97869085b9d260d5466f964783db1cae91c2fdde" alt="_images/make.updates.png"
Documentation¶
make doc-html
¶
Creates the documentation as a static HTML page with sphinx.
data:image/s3,"s3://crabby-images/33ba9/33ba9b084213cb382ae5f25b844f4300f1a3df88" alt="_images/make.doc-html.png"
make doc-latex
¶
Creates the documentation as a PDF page with sphinx.
data:image/s3,"s3://crabby-images/a0dd0/a0dd0c58326b726d92d7ab2f03da718e67946216" alt="_images/make.doc-latex.png"
Cleaning up¶
make clean
¶
Wipes test results and development.ini file.
data:image/s3,"s3://crabby-images/90ea1/90ea15b65f06b5cab04b6a3061e1f7941436dc73" alt="_images/make.clean.png"
make clean-all
¶
Completely wipes all setup files to provide green field for a new start.
data:image/s3,"s3://crabby-images/dff9c/dff9cea2c610baf16c8fdebbd3911029c76b154d" alt="_images/make.clean-all.png"