Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Introduce pip-tools to help maintain packages [#618] #624

Merged
merged 3 commits into from
Aug 10, 2021
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension


Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
35 changes: 33 additions & 2 deletions README.md
Original file line number Diff line number Diff line change
Expand Up @@ -69,9 +69,14 @@ Step into newly created `djangogirls` directory:

cd djangogirls

Create a new virtual environment (python <3.8) if needed. Then, install all the required dependencies:
Create a new virtual environment (python <3.8) if needed. Then, install all the required dependencies.
The dependencies are compiled by [pip-tools](https://github.com/jazzband/pip-tools), which
compiles `requirements.txt` ensuring compatibility between packages.

pip install -r requirements.txt
pip install pip-tools
pip-sync

There is more information on how `pip-tools` work below.

Start the [PostgreSQL database server](http://www.postgresql.org/docs/current/static/server-start.html) and enter the `psql` shell (you need to have [PostgreSQL](http://www.postgresql.org/download/) installed):

Expand Down Expand Up @@ -169,3 +174,29 @@ Several things were needed to get this working:
3. Enable delegation of domain-wide authority for the service account.
4. Enable Admin SDK for the domain.
5. Give the service account permission to access admin.directory.users service (https://admin.google.com/AdminHome?chromeless=1#OGX:ManageOauthClients).


### Using pip-tools

The packages required by the project are in `requirements.in` which looks like a regular requirements file. Specific versions of packages can be
specified, or left without a version in which case the latest version which is compatible with the other packages will be used.

If you are working on a feature which requires a new package, add it to `requirements.in`, specifying a version if necessary.
It's dependencies will be included in `requirements.txt` by the compile process.

The only time a dependency of a third party package needs adding to `requirements.in` is when a version has to be pinned.

By running `pip-compile` the requirements are compiled into `requirements.txt`.

Periodically requirements should be updated to ensure that new versions, most importantly security patches, are used.
This is done using the `-U` flag.

Once requirements are compiled, `pip-sync` will install the requirements, but also remove any packages not required.
This helps to ensure you have the packages required, but also that there isn't something installed that's missed
from `requirements.txt`.

For example:

pip-compile -U

pip-sync
38 changes: 38 additions & 0 deletions requirements.in
Original file line number Diff line number Diff line change
@@ -0,0 +1,38 @@
click==7.0
dj-database-url==0.5.0
django-autoslug==1.9.4
django-click==2.1.0
django-codemirror-widget==0.4.1
django-countries==5.3.3
django-date-extensions==3.0
django-extensions<3
django-formtools==2.1
django-gulp-rev==0.2
django-leaflet==0.24.0
django-markdown-deux==1.0.5
django-recaptcha==1.4.0
django-storages[boto3]==1.7.1
django-suit-redactor==0.0.4

django-suit==0.2.26
django-unused-media==0.1.13
# Django suit breaks with Django 2.2
django<2.1
django-sendgrid-v5==0.8.1
easy-thumbnails==2.6
freezegun==0.3.11
google-api-python-client==1.7.10
icalendar==4.0.3
oauth2client==4.1.3
pillow==6.2.0
pip-tools
psycopg2-binary==2.8.3
py-trello==0.13.0
pyquery==1.4.0
pytest-cov==2.6.0
pytest-django==3.4.3
pytest-env==0.6.2
pytest==3.9.1
sentry-sdk==1.3.1
slacker==0.9.65
vcrpy==2.0.1
180 changes: 175 additions & 5 deletions requirements.txt
Original file line number Diff line number Diff line change
@@ -1,79 +1,249 @@
#
# This file is autogenerated by pip-compile with python 3.7
# To update, run:
#
# pip-compile
#
--trusted-host pypi.python.org
--trusted-host pypi.org
--trusted-host files.pythonhosted.org

atomicwrites==1.4.0
# via pytest
attrs==21.2.0
# via pytest
boto3==1.9.28
# via django-storages
botocore==1.12.253
# via
# boto3
# s3transfer
cachetools==4.2.2
# via google-auth
certifi==2021.5.30
# via
# requests
# sentry-sdk
chardet==3.0.4
Click==7.0
# via requests
click==7.0
# via
# -r requirements.in
# django-click
# pip-tools
coverage==5.5
# via pytest-cov
cssselect==1.1.0
# via pyquery
dj-database-url==0.5.0
Django==2.0.12
# via -r requirements.in
django==2.0.13
# via
# -r requirements.in
# django-formtools
# django-leaflet
# django-recaptcha
# django-sendgrid-v5
# django-storages
# django-unused-media
# easy-thumbnails
django-autoslug==1.9.4
# via -r requirements.in
django-click==2.1.0
# via -r requirements.in
django-codemirror-widget==0.4.1
# via -r requirements.in
django-countries==5.3.3
# via -r requirements.in
django-date-extensions==3.0
# via -r requirements.in
django-extensions==2.2.1
# via -r requirements.in
django-formtools==2.1
# via -r requirements.in
django-gulp-rev==0.2
# via -r requirements.in
django-leaflet==0.24.0
# via -r requirements.in
django-markdown-deux==1.0.5
# via -r requirements.in
django-recaptcha==1.4.0
# via -r requirements.in
django-sendgrid-v5==0.8.1
django-storages==1.7.1
# via -r requirements.in
django-storages[boto3]==1.7.1
# via -r requirements.in
django-suit==0.2.26
# via -r requirements.in
django-suit-redactor==0.0.4
# via -r requirements.in
django-unused-media==0.1.13
# via -r requirements.in
docutils==0.15.2
# via botocore
easy-thumbnails==2.6
# via -r requirements.in
freezegun==0.3.11
# via -r requirements.in
future==0.18.2
# via django-sendgrid-v5
google-api-python-client==1.7.10
# via -r requirements.in
google-auth==1.34.0
# via
# google-api-python-client
# google-auth-httplib2
google-auth-httplib2==0.1.0
# via google-api-python-client
httplib2==0.19.1
# via
# google-api-python-client
# google-auth-httplib2
# oauth2client
icalendar==4.0.3
# via -r requirements.in
idna==2.8
# via
# requests
# yarl
importlib-metadata==4.6.3
# via
# pep517
# pluggy
jmespath==0.10.0
# via
# boto3
# botocore
lxml==4.4.0
# via pyquery
markdown2==2.4.0
# via django-markdown-deux
more-itertools==8.8.0
# via pytest
multidict==5.1.0
# via yarl
oauth2client==4.1.3
# via -r requirements.in
oauthlib==3.1.1
Pillow==6.2.0
# via requests-oauthlib
pep517==0.11.0
# via pip-tools
pillow==6.2.0
# via
# -r requirements.in
# easy-thumbnails
pip-tools==6.2.0
# via -r requirements.in
pluggy==0.13.1
# via pytest
psycopg2-binary==2.8.3
# via -r requirements.in
py==1.10.0
# via pytest
py-trello==0.13.0
# via -r requirements.in
pyasn1==0.4.8
# via
# oauth2client
# pyasn1-modules
# rsa
pyasn1-modules==0.2.8
# via
# google-auth
# oauth2client
pyparsing==2.4.7
# via httplib2
pyquery==1.4.0
# via -r requirements.in
pytest==3.9.1
# via
# -r requirements.in
# pytest-cov
# pytest-django
# pytest-env
pytest-cov==2.6.0
# via -r requirements.in
pytest-django==3.4.3
# via -r requirements.in
pytest-env==0.6.2
# via -r requirements.in
python-dateutil==2.8.2
# via
# botocore
# freezegun
# icalendar
# py-trello
python-http-client==3.3.2
# via
# django-sendgrid-v5
# sendgrid
pytz==2021.1
PyYAML==5.4.1
# via
# django
# icalendar
# py-trello
pyyaml==5.4.1
# via vcrpy
requests==2.22.0
# via
# py-trello
# requests-oauthlib
# slacker
requests-oauthlib==1.3.0
# via py-trello
rsa==4.7.2
# via
# google-auth
# oauth2client
s3transfer==0.1.13
# via boto3
sendgrid==6.7.1
# via django-sendgrid-v5
sentry-sdk==1.3.1
# via -r requirements.in
six==1.16.0
# via
# django-click
# django-extensions
# django-unused-media
# freezegun
# google-api-python-client
# google-auth
# google-auth-httplib2
# oauth2client
# pytest
# python-dateutil
# vcrpy
slacker==0.9.65
# via -r requirements.in
starkbank-ecdsa==1.1.1
# via sendgrid
tomli==1.2.1
# via pep517
typing-extensions==3.10.0.0
# via
# importlib-metadata
# yarl
uritemplate==3.0.1
# via google-api-python-client
urllib3==1.25.11
# via
# botocore
# requests
# sentry-sdk
vcrpy==2.0.1
# via -r requirements.in
wheel==0.37.0
# via pip-tools
wrapt==1.12.1
# via vcrpy
yarl==1.6.3
# via vcrpy
zipp==3.5.0
# via
# importlib-metadata
# pep517

# The following packages are considered to be unsafe in a requirements file:
# pip
# setuptools