|
|
@ -24,6 +24,13 @@ Reporting issues |
|
|
|
Submitting patches |
|
|
|
Submitting patches |
|
|
|
================== |
|
|
|
================== |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
- Include tests if your patch is supposed to solve a bug, and explain |
|
|
|
|
|
|
|
clearly under which circumstances the bug happens. Make sure the test fails |
|
|
|
|
|
|
|
without your patch. |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
- Try to follow `PEP8 <https://www.python.org/dev/peps/pep-0008/>`_, but you |
|
|
|
|
|
|
|
may ignore the line-length-limit if following it would make the code uglier. |
|
|
|
|
|
|
|
|
|
|
|
First time setup |
|
|
|
First time setup |
|
|
|
---------------- |
|
|
|
---------------- |
|
|
|
|
|
|
|
|
|
|
@ -81,10 +88,20 @@ Install Flask as an editable package using the current source:: |
|
|
|
cd flask |
|
|
|
cd flask |
|
|
|
pip install --editable . |
|
|
|
pip install --editable . |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
Running the testsuite |
|
|
|
|
|
|
|
--------------------- |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
The minimal requirement for running the testsuite is ``pytest``. You can |
|
|
|
|
|
|
|
install it with:: |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
pip install pytest |
|
|
|
|
|
|
|
|
|
|
|
Then you can run the testsuite with:: |
|
|
|
Then you can run the testsuite with:: |
|
|
|
|
|
|
|
|
|
|
|
pytest tests/ |
|
|
|
pytest tests/ |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
**Shortcut**: ``make test`` will ensure ``pytest`` is installed, and run it. |
|
|
|
|
|
|
|
|
|
|
|
With only pytest installed, a large part of the testsuite will get skipped |
|
|
|
With only pytest installed, a large part of the testsuite will get skipped |
|
|
|
though. Whether this is relevant depends on which part of Flask you're working |
|
|
|
though. Whether this is relevant depends on which part of Flask you're working |
|
|
|
on. Travis is set up to run the full testsuite when you submit your pull |
|
|
|
on. Travis is set up to run the full testsuite when you submit your pull |
|
|
@ -98,6 +115,8 @@ of ``pytest``. You can install it with:: |
|
|
|
The ``tox`` command will then run all tests against multiple combinations |
|
|
|
The ``tox`` command will then run all tests against multiple combinations |
|
|
|
Python versions and dependency versions. |
|
|
|
Python versions and dependency versions. |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
**Shortcut**: ``make tox-test`` will ensure ``tox`` is installed, and run it. |
|
|
|
|
|
|
|
|
|
|
|
Running test coverage |
|
|
|
Running test coverage |
|
|
|
--------------------- |
|
|
|
--------------------- |
|
|
|
Generating a report of lines that do not have unit test coverage can indicate where |
|
|
|
Generating a report of lines that do not have unit test coverage can indicate where |
|
|
@ -116,6 +135,9 @@ Generate a HTML report can be done using this command:: |
|
|
|
|
|
|
|
|
|
|
|
Full docs on ``coverage.py`` are here: https://coverage.readthedocs.io |
|
|
|
Full docs on ``coverage.py`` are here: https://coverage.readthedocs.io |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
**Shortcut**: ``make cov`` will ensure ``pytest-cov`` is installed, run it, display the results, *and* save the HTML report. |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
Caution |
|
|
|
Caution |
|
|
|
======= |
|
|
|
======= |
|
|
|
pushing |
|
|
|
pushing |
|
|
|