mirror of
https://github.com/kennethreitz/heroku-buildpack-python.git
synced 2026-06-05 23:10:16 +00:00
Compare commits
258 Commits
| Author | SHA1 | Date | |
|---|---|---|---|
| 62eaae35a4 | |||
| 2f32c5418d | |||
| 12e3a7f3e7 | |||
| e7da63f722 | |||
| a6452a1ce4 | |||
| 0b554f660f | |||
| 7b9e82175e | |||
| 73d37cbac6 | |||
| 9e1df4bbb5 | |||
| 0be9d48013 | |||
| 4750639a0d | |||
| 3de5b43447 | |||
| c3845fff9a | |||
| f3ef152624 | |||
| ef1f7f6924 | |||
| 25818765ee | |||
| 0a169e76a4 | |||
| 2f430abf07 | |||
| 07241cd751 | |||
| ae4713efd8 | |||
| 402cd8253e | |||
| aa593f127b | |||
| 67badb1829 | |||
| defa85c355 | |||
| ec364be161 | |||
| 7b4d6b5587 | |||
| e094c5469d | |||
| a7a5971372 | |||
| 45b78ab587 | |||
| 63e84aceb1 | |||
| eee8dd9a9e | |||
| 00e12b8ec2 | |||
| b56b063dd5 | |||
| d3180d3245 | |||
| 4778b1cb9d | |||
| 50a3d2d13e | |||
| 8c36a3a263 | |||
| 882f54128b | |||
| 576def4cde | |||
| 1be32ff09a | |||
| 9c2bbd109f | |||
| e5d9ed259b | |||
| 285ca2b73d | |||
| 5e4667686a | |||
| f9621add42 | |||
| 567cf2c388 | |||
| c61e61c153 | |||
| 3835aca004 | |||
| 3733383ad6 | |||
| b53d211d01 | |||
| e5830fd50d | |||
| 2efe514b14 | |||
| d442562352 | |||
| ce14e1edf8 | |||
| 39d2cd6de8 | |||
| e42b725211 | |||
| d9456b6d90 | |||
| 61591594a2 | |||
| 13bca29e13 | |||
| 95779d6711 | |||
| 166b8be2c5 | |||
| 583c1ab160 | |||
| c7f5532854 | |||
| 0fe4f91395 | |||
| 221722fb27 | |||
| e82f1e4d1e | |||
| f7e5930047 | |||
| f51dfb5eb4 | |||
| 06b7f97eff | |||
| 74873b5b71 | |||
| 731876d6e8 | |||
| a775b06d2f | |||
| 2d290e94e9 | |||
| 179e6287b1 | |||
| 18945ff1a9 | |||
| 2e630ab55c | |||
| 83d5d6caa9 | |||
| abade31848 | |||
| 9a3c1fab04 | |||
| d18f1fedd8 | |||
| d9a963c8b2 | |||
| dbeca147d2 | |||
| ca41bc87d3 | |||
| e717d0a60b | |||
| f0081e6faf | |||
| 57ec0c38ae | |||
| f1e1df2fa1 | |||
| b0f49570d4 | |||
| f072b73093 | |||
| f174d03f7d | |||
| af7332b5b2 | |||
| 6e89f2cc96 | |||
| a8fdd1e532 | |||
| 6a96169466 | |||
| 22174d6232 | |||
| 539bf80bfe | |||
| 14a6c862c8 | |||
| 3d8f6de92e | |||
| debee377b8 | |||
| c1bb04e013 | |||
| 3c64697472 | |||
| df6c8c78af | |||
| 6bcbf19bb0 | |||
| dd0aee7b06 | |||
| 23827b59c8 | |||
| 41e3fee30c | |||
| a0275888a2 | |||
| 9eddeaeef9 | |||
| 4d8c7a4639 | |||
| 23400d7862 | |||
| 1534bc3d76 | |||
| 34fccf64a4 | |||
| a75e4fdf2d | |||
| f0201c3e38 | |||
| 877aa79e19 | |||
| 730c4b314b | |||
| d0ed320447 | |||
| 18965ac04c | |||
| 2f160c5652 | |||
| 5b64b73c0b | |||
| c732097d17 | |||
| 00947abe7a | |||
| d0c98aa577 | |||
| 894083bfe5 | |||
| ce30ca052e | |||
| f9e54dc3f6 | |||
| 7d975e74a9 | |||
| 5f8360cba8 | |||
| 091656088d | |||
| 05e3d8ccce | |||
| 2f18118cd3 | |||
| 920fefce57 | |||
| fd53d4e1b0 | |||
| 329cd6eb7b | |||
| b6f042b118 | |||
| 7cbca2f5c5 | |||
| fe302d8724 | |||
| 0f0ddd52ea | |||
| a334672a1a | |||
| 7b26f0df44 | |||
| 96df073bdf | |||
| cbf074a856 | |||
| c373e80c12 | |||
| 714826eea2 | |||
| 41b342e03b | |||
| 45ceb2f451 | |||
| 3511cae1bb | |||
| ce5ff2384f | |||
| 97ac451a80 | |||
| 06fa6d23ba | |||
| df083fd3b8 | |||
| 2e1638a1b0 | |||
| e15f68944a | |||
| 9468ec2630 | |||
| c4ec6d3370 | |||
| 1ed0a96b09 | |||
| 500daaf6fc | |||
| 4a1fcafecc | |||
| 23ee27792a | |||
| de680016c9 | |||
| 646466c4dd | |||
| a2c3aaf817 | |||
| 88d6c93955 | |||
| b261158bf2 | |||
| 009d0ddbae | |||
| 17dd42113f | |||
| f767a73515 | |||
| 2608bf43dd | |||
| 25c5762cb9 | |||
| ff223597f3 | |||
| 50950c59df | |||
| 9817eb149e | |||
| a703d2febe | |||
| e304405410 | |||
| 17f992a106 | |||
| 24895082d3 | |||
| 002780c2d9 | |||
| df7f8f3507 | |||
| 312a468cce | |||
| d4b8c2aeda | |||
| f86e8079b6 | |||
| 36c6f5e388 | |||
| 91a65b2984 | |||
| 3010070d55 | |||
| fedae5ceda | |||
| 4212e06309 | |||
| fd360bda14 | |||
| 4723abb896 | |||
| 155b5eecb9 | |||
| 845635d667 | |||
| 0c26eae214 | |||
| 325a3165e4 | |||
| bf378916af | |||
| c029e44dc8 | |||
| f74d4db8c5 | |||
| 2512694df9 | |||
| f289984061 | |||
| 1d37749ec1 | |||
| da13bf1f3d | |||
| 78767e7199 | |||
| 194932889d | |||
| 4293ec5564 | |||
| 57baab9f68 | |||
| a7c20eea42 | |||
| 0a4cc2c476 | |||
| cbb718bb8b | |||
| db95cdd3f3 | |||
| 04f3ddbc86 | |||
| f06f5676e8 | |||
| c8c8995d70 | |||
| 4ee3baaded | |||
| ff94908505 | |||
| 5496c02f9f | |||
| 8d6d14b671 | |||
| 98dc586a99 | |||
| 9b185f99d5 | |||
| e8a79bbda5 | |||
| e621ff4d5e | |||
| 7a579e4eb7 | |||
| a1ed1d7b42 | |||
| 9157111d44 | |||
| 48f67ac5a6 | |||
| f6d63ea53d | |||
| 668219ae59 | |||
| 18c404f72d | |||
| 84f2fb5396 | |||
| d39b8c19b2 | |||
| 9a24c9d17d | |||
| 29abb059b6 | |||
| eb056bc58d | |||
| 70a152bd46 | |||
| 0b580d997e | |||
| 9f63582a23 | |||
| 5f33811357 | |||
| 3bd0a0e7cc | |||
| b7c3cdb607 | |||
| 3a89a84399 | |||
| 59a70d2c63 | |||
| 26ed6daeaa | |||
| cafd418220 | |||
| dded42350f | |||
| 65648fb7a8 | |||
| 45b0d18532 | |||
| 8f258ae0b8 | |||
| b80f7a953f | |||
| f27a84e015 | |||
| 5794bacbbf | |||
| e29b60dcfd | |||
| 7c95b156ce | |||
| e05346e8c1 | |||
| 9deea01360 | |||
| c19f0f83ee | |||
| 8b88d655c4 | |||
| 0e8c0077ff | |||
| cfda557b31 | |||
| 44c2b75b8d | |||
| c3849fb6d3 | |||
| 5608ed9f3c |
@@ -0,0 +1 @@
|
|||||||
|
.git/
|
||||||
@@ -0,0 +1 @@
|
|||||||
|
* @heroku/languages
|
||||||
@@ -0,0 +1,8 @@
|
|||||||
|
<!-- Hi and welcome to the Heroku Python buildpack repository!
|
||||||
|
|
||||||
|
If you meant to open a PR against a fork instead of upstream, please adjust the base branch:
|
||||||
|
https://help.github.com/articles/changing-the-base-branch-of-a-pull-request/
|
||||||
|
|
||||||
|
Otherwise thank you in advance for your Pull Request - just remember to
|
||||||
|
include as much information as possible to help the reviewers :-)
|
||||||
|
-->
|
||||||
@@ -1,3 +1,9 @@
|
|||||||
*.pyc
|
*.pyc
|
||||||
site
|
site
|
||||||
.DS_Store
|
.DS_Store
|
||||||
|
|
||||||
|
/.envrc
|
||||||
|
repos/*
|
||||||
|
|
||||||
|
#Venv
|
||||||
|
buildpack/*
|
||||||
|
|||||||
@@ -0,0 +1,5 @@
|
|||||||
|
repos:
|
||||||
|
- repo: git://github.com/detailyang/pre-commit-shell
|
||||||
|
rev: 1.0.4
|
||||||
|
hooks:
|
||||||
|
- id: shell-lint
|
||||||
+36
-7
@@ -1,9 +1,38 @@
|
|||||||
language: bash
|
language: ruby
|
||||||
|
dist: trusty
|
||||||
sudo: required
|
sudo: required
|
||||||
services:
|
rvm:
|
||||||
- docker
|
- 2.4.4
|
||||||
# install: docker pull heroku/cedar:14
|
before_script:
|
||||||
script: ./tests.sh
|
- gem install bundler -v 1.16.2
|
||||||
|
- bundle exec hatchet ci:setup
|
||||||
|
jobs:
|
||||||
|
include:
|
||||||
|
- stage: Bash linting (shellcheck)
|
||||||
|
sudo: false
|
||||||
|
before_install:
|
||||||
|
- wget -c https://goo.gl/ZzKHFv -O - | tar -xvJ -C /tmp/
|
||||||
|
- PATH="/tmp/shellcheck-latest:$PATH"
|
||||||
|
script: make check
|
||||||
|
- stage: Stack Unit Tests
|
||||||
|
services: docker
|
||||||
|
env: STACK=heroku-18
|
||||||
|
script: "./tests.sh"
|
||||||
|
- stage: Stack Unit Tests
|
||||||
|
services: docker
|
||||||
|
env: STACK=heroku-16
|
||||||
|
script: "./tests.sh"
|
||||||
|
- stage: Stack Unit Tests
|
||||||
|
services: docker
|
||||||
|
env: STACK=cedar-14
|
||||||
|
script: "./tests.sh"
|
||||||
|
- stage: Hatchet Integration
|
||||||
|
script: "bundle exec rspec"
|
||||||
env:
|
env:
|
||||||
- STACK=heroku-16
|
global:
|
||||||
- STACK=cedar-14
|
- HATCHET_RETRIES=3
|
||||||
|
- IS_RUNNING_ON_CI=true
|
||||||
|
- HATCHET_APP_LIMIT=5
|
||||||
|
- HATCHET_DEPLOY_STRATEGY=git
|
||||||
|
- secure: yjtlPE5FbVxTKnjUy/tZUBgSEf4qADD3QOxtgziuid73S0U/1IEXlMGFULsQzIjtlHKmHeywZqpVVEpthIH4RuT7uoX1Pb7SSM/g0T8fT3VoEFbFK1uYl0oZQbUS4Klxv9tPiumj8if3m6ULEGIz1X0wZcMOC0tMLwVCnwmap0E=
|
||||||
|
- secure: ZeFTHWwnpIKE9nAqs88ocmiQh7bKce84lilGm5J23nf3N6V4wNyLwqlkvsM008WGBCaOg9AUx7ZunasT0ANsR5gLP3eV2UUg7ILdRgV2Gy13eNRFheC4PHdN92RqQ3aKoqlIv2K999xlhVjod0NzhkQQXB6PddfQINbuU7ks6As=
|
||||||
|
|||||||
+213
@@ -1,5 +1,218 @@
|
|||||||
# Python Buildpack Changelog
|
# Python Buildpack Changelog
|
||||||
|
|
||||||
|
# 145 (2018-11-08)
|
||||||
|
|
||||||
|
Python 3.7.1, 3.6.7, 3.5.6 and 3.4.9 now available on all Heroku stacks.
|
||||||
|
|
||||||
|
# 144 (2018-10-10)
|
||||||
|
|
||||||
|
Switch to cautious upgrade for Pipenv install to ensure the pinned pip version
|
||||||
|
is used with Pipenv
|
||||||
|
|
||||||
|
# 143 (2018-10-09)
|
||||||
|
|
||||||
|
Add support for detecting SLUGIFY_USES_TEXT_UNIDECODE, which is required to
|
||||||
|
install Apache Airflow version 1.10 or higher.
|
||||||
|
|
||||||
|
# 142 (2018-10-08)
|
||||||
|
|
||||||
|
Improvements to Python install messaging
|
||||||
|
|
||||||
|
# 139, 140, 141
|
||||||
|
|
||||||
|
No user-facing changes, documenting for version clarity
|
||||||
|
|
||||||
|
# 138 (2018-08-01)
|
||||||
|
|
||||||
|
Use stack image SQLite3 instead of vendoring
|
||||||
|
|
||||||
|
# 137 (2018-07-17)
|
||||||
|
|
||||||
|
Prevent 3.7.0 from appearing as unsupported in buildpack messaging.
|
||||||
|
|
||||||
|
# 136 (2018-06-28)
|
||||||
|
|
||||||
|
Upgrade to 3.6.6 and support 3.7.0 on all runtimes.
|
||||||
|
|
||||||
|
# 135 (2018-05-29)
|
||||||
|
|
||||||
|
Upgrade Pipenv to v2018.5.18.
|
||||||
|
|
||||||
|
# 134 (2018-05-02)
|
||||||
|
|
||||||
|
Default to 3.6.5, bugfixes.
|
||||||
|
|
||||||
|
# 133
|
||||||
|
|
||||||
|
Fixes for Pip 10 release.
|
||||||
|
|
||||||
|
# 132
|
||||||
|
|
||||||
|
Improve pip installation, with the release of v9.0.2.
|
||||||
|
|
||||||
|
# 131
|
||||||
|
|
||||||
|
Fix bug with pip.
|
||||||
|
|
||||||
|
# 130
|
||||||
|
|
||||||
|
Better upgrade strategy for pip.
|
||||||
|
|
||||||
|
# 129
|
||||||
|
|
||||||
|
Don't upgrade pip (from v128).
|
||||||
|
|
||||||
|
# 128
|
||||||
|
|
||||||
|
Upgrade pip, pin to Pipenv v11.8.2.
|
||||||
|
|
||||||
|
# 127
|
||||||
|
|
||||||
|
Pin to Pipenv v11.7.1.
|
||||||
|
|
||||||
|
# 126
|
||||||
|
|
||||||
|
Bugfixes.
|
||||||
|
|
||||||
|
# 125
|
||||||
|
|
||||||
|
Bugfixes.
|
||||||
|
|
||||||
|
# 124
|
||||||
|
|
||||||
|
Update buildpack to automatically install `[dev-packages]` during Heroku CI Pipenv builds.
|
||||||
|
|
||||||
|
- Skip installs if Pipfile.lock hasn't changed, and uninstall stale dependencies with Pipenv.
|
||||||
|
- Set `PYTHONPATH` during collectstatic runs.
|
||||||
|
- No longer warn if there is no `Procfile`.
|
||||||
|
- Update Pipenv's "3.6" runtime specifier to point to "3.6.4".
|
||||||
|
|
||||||
|
# 123
|
||||||
|
|
||||||
|
Update gunicorn `init.d` script to allow overrides.
|
||||||
|
|
||||||
|
# 122
|
||||||
|
|
||||||
|
Update default Python to v3.6.4.
|
||||||
|
|
||||||
|
# 121
|
||||||
|
|
||||||
|
Update default Python to v3.6.3.
|
||||||
|
|
||||||
|
# 120
|
||||||
|
|
||||||
|
Use `$ pipenv --deploy`.
|
||||||
|
|
||||||
|
# 119
|
||||||
|
|
||||||
|
Improvements to Pipenv support, warning on unsupported Python versions.
|
||||||
|
|
||||||
|
- We now warn when a user is not using latest 2.x or 3.x Python.
|
||||||
|
- Heroku now supports `[requires]` `python_full_version` in addition to `python_version`.
|
||||||
|
|
||||||
|
# 118
|
||||||
|
|
||||||
|
Improvements to Pipenv support.
|
||||||
|
|
||||||
|
# 117
|
||||||
|
|
||||||
|
Bug fix.
|
||||||
|
|
||||||
|
# 116
|
||||||
|
|
||||||
|
Vendoring improvements.
|
||||||
|
|
||||||
|
- Geos libraries should work on Heroku-16 now.
|
||||||
|
- The libffi/libmemcached vendoring step is now skipped on Heroku-16 (since they are installed in the base image).
|
||||||
|
|
||||||
|
# 115
|
||||||
|
|
||||||
|
Revert a pull request.
|
||||||
|
|
||||||
|
- No longer using `sub_env` for `pip install` step.
|
||||||
|
|
||||||
|
# 114
|
||||||
|
|
||||||
|
- Bugfixes.
|
||||||
|
|
||||||
|
Blacklisting `PYTHONHOME` and `PYTHONPATH` for older apps. Upgrades to nltk support.
|
||||||
|
|
||||||
|
# 113
|
||||||
|
|
||||||
|
Updates to Pipenv support.
|
||||||
|
|
||||||
|
# 112
|
||||||
|
|
||||||
|
Bugfix.
|
||||||
|
|
||||||
|
- Fixed grep output bug.
|
||||||
|
|
||||||
|
# 111
|
||||||
|
|
||||||
|
Linting, bugfixes.
|
||||||
|
|
||||||
|
# 110
|
||||||
|
|
||||||
|
Update default Python to 3.6.2.
|
||||||
|
|
||||||
|
# 109
|
||||||
|
|
||||||
|
Update Default Python to 3.6.1, bugfixes.
|
||||||
|
|
||||||
|
- Fixed automatic pip uninstall of dependencies removed from requirements.txt.
|
||||||
|
|
||||||
|
# 108
|
||||||
|
|
||||||
|
Fix output for collectstatic step.
|
||||||
|
|
||||||
|
# 107
|
||||||
|
|
||||||
|
Bugfix for C dependency installation.
|
||||||
|
|
||||||
|
# 106
|
||||||
|
|
||||||
|
Don't install packages that could mess up packaging.
|
||||||
|
|
||||||
|
- The Python buildpack will automatically remove `six`, `pyparsing`, `appdirs`,
|
||||||
|
`setuptools`, and `distribute` from a `requirements.txt` file now, as these
|
||||||
|
packages are provided by the Python buildpack.
|
||||||
|
|
||||||
|
# 105
|
||||||
|
|
||||||
|
Improvements to output messaging.
|
||||||
|
|
||||||
|
# 104
|
||||||
|
|
||||||
|
General improvements.
|
||||||
|
|
||||||
|
- Fix for Heroku CI.
|
||||||
|
- Use `pkg_resources` to check if a distribution is installed instead of
|
||||||
|
parsing `requirements.txt`. ([#395][395])
|
||||||
|
|
||||||
|
[395]: https://github.com/heroku/heroku-buildpack-python/pull/395
|
||||||
|
|
||||||
|
## 103
|
||||||
|
|
||||||
|
Bug fixes and improvements.
|
||||||
|
|
||||||
|
- Fix for Pipenv.
|
||||||
|
- Fix for Heroku CI.
|
||||||
|
- Improve handling of WEB_CONCURRENCY when using multiple buildpacks.
|
||||||
|
- Adjust environment variables set during the build to more closely match those in the dyno environment (DYNO is now available, STACK is not).
|
||||||
|
- Restore the build cache prior to running bin/pre_compile.
|
||||||
|
|
||||||
|
## 102
|
||||||
|
|
||||||
|
Buildpack code cleanup.
|
||||||
|
|
||||||
|
- Improved messaging around NLTK.
|
||||||
|
|
||||||
|
## 101
|
||||||
|
|
||||||
|
Updated setuptools installation method.
|
||||||
|
|
||||||
|
- Improved pipenv support.
|
||||||
|
|
||||||
## 100
|
## 100
|
||||||
|
|
||||||
Preliminary pipenv support.
|
Preliminary pipenv support.
|
||||||
|
|||||||
+6
-4
@@ -1,11 +1,13 @@
|
|||||||
FROM heroku/heroku:16-build
|
FROM heroku/heroku:16-build
|
||||||
|
|
||||||
WORKDIR /app
|
WORKDIR /app
|
||||||
ENV WORKSPACE_DIR=/app/builds
|
ENV WORKSPACE_DIR="/app/builds" \
|
||||||
|
S3_BUCKET="lang-python" \
|
||||||
|
S3_PREFIX="heroku-16/"
|
||||||
|
|
||||||
RUN apt-get update && apt-get install -y python-pip
|
RUN apt-get update && apt-get install -y python-pip && rm -rf /var/lib/apt/lists/*
|
||||||
|
|
||||||
# Install bob-builder application
|
COPY requirements.txt /app/
|
||||||
RUN pip install bob-builder==0.0.5
|
RUN pip install --disable-pip-version-check --no-cache-dir -r /app/requirements.txt
|
||||||
|
|
||||||
COPY . /app
|
COPY . /app
|
||||||
@@ -0,0 +1,13 @@
|
|||||||
|
FROM heroku/heroku:18-build
|
||||||
|
|
||||||
|
WORKDIR /app
|
||||||
|
ENV WORKSPACE_DIR="/app/builds" \
|
||||||
|
S3_BUCKET="lang-python" \
|
||||||
|
S3_PREFIX="heroku-18/"
|
||||||
|
|
||||||
|
RUN apt-get update && apt-get install -y python-pip && rm -rf /var/lib/apt/lists/*
|
||||||
|
|
||||||
|
COPY requirements.txt /app/
|
||||||
|
RUN pip install --disable-pip-version-check --no-cache-dir -r /app/requirements.txt
|
||||||
|
|
||||||
|
COPY . /app
|
||||||
@@ -0,0 +1,6 @@
|
|||||||
|
source "https://rubygems.org"
|
||||||
|
|
||||||
|
gem "rspec"
|
||||||
|
gem "heroku_hatchet"
|
||||||
|
gem "rspec-retry"
|
||||||
|
gem "rake"
|
||||||
@@ -0,0 +1,71 @@
|
|||||||
|
GEM
|
||||||
|
remote: https://rubygems.org/
|
||||||
|
specs:
|
||||||
|
activesupport (5.2.1)
|
||||||
|
concurrent-ruby (~> 1.0, >= 1.0.2)
|
||||||
|
i18n (>= 0.7, < 2)
|
||||||
|
minitest (~> 5.1)
|
||||||
|
tzinfo (~> 1.1)
|
||||||
|
concurrent-ruby (1.1.3)
|
||||||
|
diff-lcs (1.3)
|
||||||
|
erubis (2.7.0)
|
||||||
|
excon (0.62.0)
|
||||||
|
heroics (0.0.25)
|
||||||
|
erubis (~> 2.0)
|
||||||
|
excon
|
||||||
|
moneta
|
||||||
|
multi_json (>= 1.9.2)
|
||||||
|
heroku_hatchet (4.0.6)
|
||||||
|
excon (~> 0)
|
||||||
|
minitest-retry (~> 0.1.9)
|
||||||
|
platform-api (~> 2)
|
||||||
|
repl_runner (~> 0.0.3)
|
||||||
|
rrrretry (~> 1)
|
||||||
|
thor (~> 0)
|
||||||
|
threaded (~> 0)
|
||||||
|
i18n (1.1.1)
|
||||||
|
concurrent-ruby (~> 1.0)
|
||||||
|
minitest (5.11.3)
|
||||||
|
minitest-retry (0.1.9)
|
||||||
|
minitest (>= 5.0)
|
||||||
|
moneta (1.0.0)
|
||||||
|
multi_json (1.13.1)
|
||||||
|
platform-api (2.2.0)
|
||||||
|
heroics (~> 0.0.25)
|
||||||
|
moneta (~> 1.0.0)
|
||||||
|
rake (12.3.1)
|
||||||
|
repl_runner (0.0.3)
|
||||||
|
activesupport
|
||||||
|
rrrretry (1.0.0)
|
||||||
|
rspec (3.8.0)
|
||||||
|
rspec-core (~> 3.8.0)
|
||||||
|
rspec-expectations (~> 3.8.0)
|
||||||
|
rspec-mocks (~> 3.8.0)
|
||||||
|
rspec-core (3.8.0)
|
||||||
|
rspec-support (~> 3.8.0)
|
||||||
|
rspec-expectations (3.8.1)
|
||||||
|
diff-lcs (>= 1.2.0, < 2.0)
|
||||||
|
rspec-support (~> 3.8.0)
|
||||||
|
rspec-mocks (3.8.0)
|
||||||
|
diff-lcs (>= 1.2.0, < 2.0)
|
||||||
|
rspec-support (~> 3.8.0)
|
||||||
|
rspec-retry (0.6.1)
|
||||||
|
rspec-core (> 3.3)
|
||||||
|
rspec-support (3.8.0)
|
||||||
|
thor (0.20.3)
|
||||||
|
thread_safe (0.3.6)
|
||||||
|
threaded (0.0.4)
|
||||||
|
tzinfo (1.2.5)
|
||||||
|
thread_safe (~> 0.1)
|
||||||
|
|
||||||
|
PLATFORMS
|
||||||
|
ruby
|
||||||
|
|
||||||
|
DEPENDENCIES
|
||||||
|
heroku_hatchet
|
||||||
|
rake
|
||||||
|
rspec
|
||||||
|
rspec-retry
|
||||||
|
|
||||||
|
BUNDLED WITH
|
||||||
|
1.16.3
|
||||||
@@ -1,6 +1,6 @@
|
|||||||
MIT License:
|
MIT License:
|
||||||
|
|
||||||
Copyright (C) 2016 Heroku, Inc.
|
Copyright (C) 2017 Heroku, Inc.
|
||||||
|
|
||||||
Permission is hereby granted, free of charge, to any person obtaining a copy of this software and associated documentation files (the "Software"), to deal in the Software without restriction, including without limitation the rights to use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of the Software, and to permit persons to whom the Software is furnished to do so, subject to the following conditions:
|
Permission is hereby granted, free of charge, to any person obtaining a copy of this software and associated documentation files (the "Software"), to deal in the Software without restriction, including without limitation the rights to use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of the Software, and to permit persons to whom the Software is furnished to do so, subject to the following conditions:
|
||||||
|
|
||||||
|
|||||||
@@ -1,13 +1,41 @@
|
|||||||
# These targets are not files
|
# These targets are not files
|
||||||
.PHONY: tests
|
.PHONY: tests
|
||||||
|
|
||||||
test: test-cedar-14
|
test: test-heroku-16
|
||||||
|
|
||||||
|
check:
|
||||||
|
@shellcheck -x bin/compile bin/detect bin/release bin/test-compile bin/utils bin/warnings
|
||||||
|
@shellcheck -x bin/steps/collectstatic bin/steps/eggpath-fix bin/steps/eggpath-fix2 bin/steps/gdal bin/steps/geo-libs bin/steps/mercurial bin/steps/nltk bin/steps/pip-install bin/steps/pip-uninstall bin/steps/pipenv bin/steps/pipenv-python-version bin/steps/pylibmc bin/steps/python
|
||||||
|
@shellcheck -x bin/steps/hooks/*
|
||||||
|
|
||||||
test-cedar-14:
|
test-cedar-14:
|
||||||
@echo "Running tests in docker (cedar-14)..."
|
@echo "Running tests in docker (cedar-14)..."
|
||||||
@docker run -v $(shell pwd):/buildpack:ro --rm -it -e "STACK=cedar-14" heroku/cedar:14 bash -c 'cp -r /buildpack /buildpack_test; cd /buildpack_test/; test/run;'
|
@docker run -v $(shell pwd):/buildpack:ro --rm -it -e "STACK=cedar-14" heroku/cedar:14 bash -c 'cp -r /buildpack /buildpack_test; cd /buildpack_test/; test/run;'
|
||||||
@echo ""
|
@echo ""
|
||||||
|
|
||||||
|
test-heroku-16:
|
||||||
|
@echo "Running tests in docker (heroku-16)..."
|
||||||
|
@docker run -v $(shell pwd):/buildpack:ro --rm -it -e "STACK=heroku-16" heroku/heroku:16-build bash -c 'cp -r /buildpack /buildpack_test; cd /buildpack_test/; test/run;'
|
||||||
|
@echo ""
|
||||||
|
|
||||||
|
test-heroku-18:
|
||||||
|
@echo "Running tests in docker (heroku-18)..."
|
||||||
|
@docker run -v $(shell pwd):/buildpack:ro --rm -it -e "STACK=heroku-18" heroku/heroku:18-build bash -c 'cp -r /buildpack /buildpack_test; cd /buildpack_test/; test/run;'
|
||||||
|
@echo ""
|
||||||
|
|
||||||
|
buildenv-heroku-16:
|
||||||
|
@echo "Creating build environment (heroku-16)..."
|
||||||
|
@echo
|
||||||
|
@docker build --pull -t python-buildenv-heroku-16 .
|
||||||
|
@echo
|
||||||
|
@echo "Usage..."
|
||||||
|
@echo
|
||||||
|
@echo " $$ export AWS_ACCESS_KEY_ID=foo AWS_SECRET_ACCESS_KEY=bar # Optional unless deploying"
|
||||||
|
@echo " $$ bob build runtimes/python-2.7.13"
|
||||||
|
@echo " $$ bob deploy runtimes/python-2.7.13"
|
||||||
|
@echo
|
||||||
|
@docker run -it --rm python-buildenv-heroku-16
|
||||||
|
|
||||||
tools:
|
tools:
|
||||||
git clone https://github.com/kennethreitz/pip-pop.git
|
git clone https://github.com/kennethreitz/pip-pop.git
|
||||||
mv pip-pop/bin/* vendor/pip-pop/
|
mv pip-pop/bin/* vendor/pip-pop/
|
||||||
|
|||||||
@@ -0,0 +1,137 @@
|
|||||||
|
This buildpack includes some vendorized packages to ease installation.
|
||||||
|
|
||||||
|
jq license
|
||||||
|
----------
|
||||||
|
|
||||||
|
Permission is hereby granted, free of charge, to any person obtaining a copy
|
||||||
|
of this software and associated documentation files (the "Software"), to deal
|
||||||
|
in the Software without restriction, including without limitation the rights
|
||||||
|
to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
|
||||||
|
copies of the Software, and to permit persons to whom the Software is
|
||||||
|
furnished to do so, subject to the following conditions:
|
||||||
|
|
||||||
|
The above copyright notice and this permission notice shall be included in all
|
||||||
|
copies or substantial portions of the Software.
|
||||||
|
|
||||||
|
THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
|
||||||
|
IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
|
||||||
|
FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
|
||||||
|
AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
|
||||||
|
LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
|
||||||
|
OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
|
||||||
|
SOFTWARE.
|
||||||
|
|
||||||
|
|
||||||
|
shunit2 license
|
||||||
|
---------------
|
||||||
|
|
||||||
|
Copyright © 2007 Free Software Foundation, Inc. <http://fsf.org/>
|
||||||
|
|
||||||
|
Everyone is permitted to copy and distribute verbatim copies of this license document, but changing it is not allowed.
|
||||||
|
|
||||||
|
This version of the GNU Lesser General Public License incorporates the terms and conditions of version 3 of the GNU General Public License, supplemented by the additional permissions listed below.
|
||||||
|
|
||||||
|
0. Additional Definitions.
|
||||||
|
|
||||||
|
As used herein, “this License” refers to version 3 of the GNU Lesser General Public License, and the “GNU GPL” refers to version 3 of the GNU General Public License.
|
||||||
|
|
||||||
|
“The Library” refers to a covered work governed by this License, other than an Application or a Combined Work as defined below.
|
||||||
|
|
||||||
|
An “Application” is any work that makes use of an interface provided by the Library, but which is not otherwise based on the Library. Defining a subclass of a class defined by the Library is deemed a mode of using an interface provided by the Library.
|
||||||
|
|
||||||
|
A “Combined Work” is a work produced by combining or linking an Application with the Library. The particular version of the Library with which the Combined Work was made is also called the “Linked Version”.
|
||||||
|
|
||||||
|
The “Minimal Corresponding Source” for a Combined Work means the Corresponding Source for the Combined Work, excluding any source code for portions of the Combined Work that, considered in isolation, are based on the Application, and not on the Linked Version.
|
||||||
|
|
||||||
|
The “Corresponding Application Code” for a Combined Work means the object code and/or source code for the Application, including any data and utility programs needed for reproducing the Combined Work from the Application, but excluding the System Libraries of the Combined Work.
|
||||||
|
|
||||||
|
1. Exception to Section 3 of the GNU GPL.
|
||||||
|
|
||||||
|
You may convey a covered work under sections 3 and 4 of this License without being bound by section 3 of the GNU GPL.
|
||||||
|
|
||||||
|
2. Conveying Modified Versions.
|
||||||
|
|
||||||
|
If you modify a copy of the Library, and, in your modifications, a facility refers to a function or data to be supplied by an Application that uses the facility (other than as an argument passed when the facility is invoked), then you may convey a copy of the modified version:
|
||||||
|
|
||||||
|
a) under this License, provided that you make a good faith effort to ensure that, in the event an Application does not supply the function or data, the facility still operates, and performs whatever part of its purpose remains meaningful, or
|
||||||
|
b) under the GNU GPL, with none of the additional permissions of this License applicable to that copy.
|
||||||
|
3. Object Code Incorporating Material from Library Header Files.
|
||||||
|
|
||||||
|
The object code form of an Application may incorporate material from a header file that is part of the Library. You may convey such object code under terms of your choice, provided that, if the incorporated material is not limited to numerical parameters, data structure layouts and accessors, or small macros, inline functions and templates (ten or fewer lines in length), you do both of the following:
|
||||||
|
|
||||||
|
a) Give prominent notice with each copy of the object code that the Library is used in it and that the Library and its use are covered by this License.
|
||||||
|
b) Accompany the object code with a copy of the GNU GPL and this license document.
|
||||||
|
4. Combined Works.
|
||||||
|
|
||||||
|
You may convey a Combined Work under terms of your choice that, taken together, effectively do not restrict modification of the portions of the Library contained in the Combined Work and reverse engineering for debugging such modifications, if you also do each of the following:
|
||||||
|
|
||||||
|
a) Give prominent notice with each copy of the Combined Work that the Library is used in it and that the Library and its use are covered by this License.
|
||||||
|
b) Accompany the Combined Work with a copy of the GNU GPL and this license document.
|
||||||
|
c) For a Combined Work that displays copyright notices during execution, include the copyright notice for the Library among these notices, as well as a reference directing the user to the copies of the GNU GPL and this license document.
|
||||||
|
d) Do one of the following:
|
||||||
|
0) Convey the Minimal Corresponding Source under the terms of this License, and the Corresponding Application Code in a form suitable for, and under terms that permit, the user to recombine or relink the Application with a modified version of the Linked Version to produce a modified Combined Work, in the manner specified by section 6 of the GNU GPL for conveying Corresponding Source.
|
||||||
|
1) Use a suitable shared library mechanism for linking with the Library. A suitable mechanism is one that (a) uses at run time a copy of the Library already present on the user's computer system, and (b) will operate properly with a modified version of the Library that is interface-compatible with the Linked Version.
|
||||||
|
e) Provide Installation Information, but only if you would otherwise be required to provide such information under section 6 of the GNU GPL, and only to the extent that such information is necessary to install and execute a modified version of the Combined Work produced by recombining or relinking the Application with a modified version of the Linked Version. (If you use option 4d0, the Installation Information must accompany the Minimal Corresponding Source and Corresponding Application Code. If you use option 4d1, you must provide the Installation Information in the manner specified by section 6 of the GNU GPL for conveying Corresponding Source.)
|
||||||
|
5. Combined Libraries.
|
||||||
|
|
||||||
|
You may place library facilities that are a work based on the Library side by side in a single library together with other library facilities that are not Applications and are not covered by this License, and convey such a combined library under terms of your choice, if you do both of the following:
|
||||||
|
|
||||||
|
a) Accompany the combined library with a copy of the same work based on the Library, uncombined with any other library facilities, conveyed under the terms of this License.
|
||||||
|
b) Give prominent notice with the combined library that part of it is a work based on the Library, and explaining where to find the accompanying uncombined form of the same work.
|
||||||
|
6. Revised Versions of the GNU Lesser General Public License.
|
||||||
|
|
||||||
|
The Free Software Foundation may publish revised and/or new versions of the GNU Lesser General Public License from time to time. Such new versions will be similar in spirit to the present version, but may differ in detail to address new problems or concerns.
|
||||||
|
|
||||||
|
Each version is given a distinguishing version number. If the Library as you received it specifies that a certain numbered version of the GNU Lesser General Public License “or any later version” applies to it, you have the option of following the terms and conditions either of that published version or of any later version published by the Free Software Foundation. If the Library as you received it does not specify a version number of the GNU Lesser General Public License, you may choose any version of the GNU Lesser General Public License ever published by the Free Software Foundation.
|
||||||
|
|
||||||
|
If the Library as you received it specifies that a proxy can decide whether future versions of the GNU Lesser General Public License shall apply, that proxy's public statement of acceptance of any version is permanent authorization for you to choose that version for the Library.
|
||||||
|
|
||||||
|
get-pip.py license
|
||||||
|
------------------
|
||||||
|
|
||||||
|
Copyright (c) 2008-2016 The pip developers (see AUTHORS.txt file)
|
||||||
|
|
||||||
|
Permission is hereby granted, free of charge, to any person obtaining
|
||||||
|
a copy of this software and associated documentation files (the
|
||||||
|
"Software"), to deal in the Software without restriction, including
|
||||||
|
without limitation the rights to use, copy, modify, merge, publish,
|
||||||
|
distribute, sublicense, and/or sell copies of the Software, and to
|
||||||
|
permit persons to whom the Software is furnished to do so, subject to
|
||||||
|
the following conditions:
|
||||||
|
|
||||||
|
The above copyright notice and this permission notice shall be
|
||||||
|
included in all copies or substantial portions of the Software.
|
||||||
|
|
||||||
|
THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
|
||||||
|
EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
|
||||||
|
MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
|
||||||
|
NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE
|
||||||
|
LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION
|
||||||
|
OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION
|
||||||
|
WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
|
||||||
|
|
||||||
|
|
||||||
|
pip-pop license
|
||||||
|
---------------
|
||||||
|
|
||||||
|
The MIT License (MIT)
|
||||||
|
|
||||||
|
Copyright (c) 2014 Kenneth Reitz.
|
||||||
|
|
||||||
|
Permission is hereby granted, free of charge, to any person obtaining a copy
|
||||||
|
of this software and associated documentation files (the "Software"), to deal
|
||||||
|
in the Software without restriction, including without limitation the rights
|
||||||
|
to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
|
||||||
|
copies of the Software, and to permit persons to whom the Software is
|
||||||
|
furnished to do so, subject to the following conditions:
|
||||||
|
|
||||||
|
The above copyright notice and this permission notice shall be included in
|
||||||
|
all copies or substantial portions of the Software.
|
||||||
|
|
||||||
|
THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
|
||||||
|
IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
|
||||||
|
FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
|
||||||
|
AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
|
||||||
|
LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
|
||||||
|
OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
|
||||||
|
THE SOFTWARE.
|
||||||
@@ -0,0 +1,9 @@
|
|||||||
|
[[source]]
|
||||||
|
url = "https://pypi.python.org/simple"
|
||||||
|
verify_ssl = true
|
||||||
|
name = "pypi"
|
||||||
|
|
||||||
|
[dev-packages]
|
||||||
|
|
||||||
|
[packages]
|
||||||
|
"bob-builder" = "==0.0.13"
|
||||||
Generated
+52
@@ -0,0 +1,52 @@
|
|||||||
|
{
|
||||||
|
"_meta": {
|
||||||
|
"hash": {
|
||||||
|
"sha256": "36d17c46a8b1b844b3cae475f6f42d6c0a9e59b2a9685cbcdc0985656a7a129f"
|
||||||
|
},
|
||||||
|
"host-environment-markers": {
|
||||||
|
"implementation_name": "cpython",
|
||||||
|
"implementation_version": "3.6.3",
|
||||||
|
"os_name": "posix",
|
||||||
|
"platform_machine": "x86_64",
|
||||||
|
"platform_python_implementation": "CPython",
|
||||||
|
"platform_release": "16.7.0",
|
||||||
|
"platform_system": "Darwin",
|
||||||
|
"platform_version": "Darwin Kernel Version 16.7.0: Thu Jun 15 17:36:27 PDT 2017; root:xnu-3789.70.16~2/RELEASE_X86_64",
|
||||||
|
"python_full_version": "3.6.3",
|
||||||
|
"python_version": "3.6",
|
||||||
|
"sys_platform": "darwin"
|
||||||
|
},
|
||||||
|
"pipfile-spec": 6,
|
||||||
|
"requires": {},
|
||||||
|
"sources": [
|
||||||
|
{
|
||||||
|
"name": "pypi",
|
||||||
|
"url": "https://pypi.python.org/simple",
|
||||||
|
"verify_ssl": true
|
||||||
|
}
|
||||||
|
]
|
||||||
|
},
|
||||||
|
"default": {
|
||||||
|
"bob-builder": {
|
||||||
|
"hashes": [
|
||||||
|
"sha256:b4de49a8e436fcaf82236ea43f78413b4a4c92100726e382ab57b6bdfb38fe64",
|
||||||
|
"sha256:288e3e765c4890fe9a63ae52ac6b4a963c13fe508482c70ff701a5ae21b9a673"
|
||||||
|
],
|
||||||
|
"version": "==0.0.13"
|
||||||
|
},
|
||||||
|
"boto": {
|
||||||
|
"hashes": [
|
||||||
|
"sha256:13be844158d1bd80a94c972c806ec8381b9ea72035aa06123c5db6bc6a6f3ead",
|
||||||
|
"sha256:deb8925b734b109679e3de65856018996338758f4b916ff4fe7bb62b6d7000d1"
|
||||||
|
],
|
||||||
|
"version": "==2.48.0"
|
||||||
|
},
|
||||||
|
"docopt": {
|
||||||
|
"hashes": [
|
||||||
|
"sha256:49b3a825280bd66b3aa83585ef59c4a8c82f2c8a522dbe754a8bc8d08c85c491"
|
||||||
|
],
|
||||||
|
"version": "==0.6.2"
|
||||||
|
}
|
||||||
|
},
|
||||||
|
"develop": {}
|
||||||
|
}
|
||||||
@@ -4,11 +4,11 @@
|
|||||||
|
|
||||||
[](https://travis-ci.org/heroku/heroku-buildpack-python)
|
[](https://travis-ci.org/heroku/heroku-buildpack-python)
|
||||||
|
|
||||||
This is the official [Heroku buildpack](https://devcenter.heroku.com/articles/buildpacks) for Python apps, powered by [pip](https://pip.pypa.io/) and other excellent software.
|
This is the official [Heroku buildpack](https://devcenter.heroku.com/articles/buildpacks) for Python apps, powered by [Pipenv](http://docs.pipenv.org/), [pip](https://pip.pypa.io/) and other excellent software.
|
||||||
|
|
||||||
Recommended web frameworks include **Django** and **Flask**. The recommended webserver is **Gunicorn**. There are no restrictions around what software can be used (as long as it's pip-installable). Web processes must bind to `$PORT`, and only the HTTP protocol is permitted for incoming connections.
|
Recommended web frameworks include **Django** and **Flask**. The recommended webserver is **Gunicorn**. There are no restrictions around what software can be used (as long as it's pip-installable). Web processes must bind to `$PORT`, and only the HTTP protocol is permitted for incoming connections.
|
||||||
|
|
||||||
Some Python packages with obscure C dependencies (e.g. scipy) are [not compatible](https://devcenter.heroku.com/articles/python-c-deps).
|
Python packages with C dependencies that are not [available on the stack image](https://devcenter.heroku.com/articles/stack-packages) are generally not supported, unless `manylinux` wheels are provided by the package maintainers (common). For recommended solutions, check out [this article](https://devcenter.heroku.com/articles/python-c-deps) for more information.
|
||||||
|
|
||||||
See it in Action
|
See it in Action
|
||||||
----------------
|
----------------
|
||||||
@@ -16,24 +16,22 @@ See it in Action
|
|||||||
Deploying a Python application couldn't be easier:
|
Deploying a Python application couldn't be easier:
|
||||||
|
|
||||||
$ ls
|
$ ls
|
||||||
Procfile requirements.txt web.py
|
Pipfile Pipfile.lock Procfile web.py
|
||||||
|
|
||||||
$ heroku create --buildpack heroku/python
|
$ heroku create --buildpack heroku/python
|
||||||
|
|
||||||
$ git push heroku master
|
$ git push heroku master
|
||||||
...
|
…
|
||||||
-----> Python app detected
|
-----> Python app detected
|
||||||
-----> Installing python-2.7.13
|
-----> Installing python-3.6.6
|
||||||
$ pip install -r requirements.txt
|
-----> Installing pip
|
||||||
Collecting requests (from -r requirements.txt (line 1))
|
-----> Installing requirements with Pipenv 2018.5.18…
|
||||||
Downloading requests-2.12.4-py2.py3-none-any.whl (576KB)
|
...
|
||||||
Installing collected packages: requests
|
Installing dependencies from Pipfile…
|
||||||
Successfully installed requests-2.12.4
|
|
||||||
|
|
||||||
-----> Discovering process types
|
-----> Discovering process types
|
||||||
Procfile declares types -> (none)
|
Procfile declares types -> (none)
|
||||||
|
|
||||||
A `requirements.txt` file must be present at the root of your application's repository.
|
A `Pipfile` or `requirements.txt` must be present at the root of your application's repository.
|
||||||
|
|
||||||
You can also specify the latest production release of this buildpack for upcoming builds of an existing application:
|
You can also specify the latest production release of this buildpack for upcoming builds of an existing application:
|
||||||
|
|
||||||
@@ -43,14 +41,23 @@ You can also specify the latest production release of this buildpack for upcomin
|
|||||||
Specify a Python Runtime
|
Specify a Python Runtime
|
||||||
------------------------
|
------------------------
|
||||||
|
|
||||||
Specific versions of the Python runtime can be specified with a `runtime.txt` file:
|
Specific versions of the Python runtime can be specified in your `Pipfile`:
|
||||||
|
|
||||||
|
[requires]
|
||||||
|
python_version = "2.7"
|
||||||
|
|
||||||
|
Or, more specifically:
|
||||||
|
|
||||||
|
[requires]
|
||||||
|
python_full_version = "2.7.15"
|
||||||
|
|
||||||
|
Or, with a `runtime.txt` file:
|
||||||
|
|
||||||
$ cat runtime.txt
|
$ cat runtime.txt
|
||||||
python-3.6.0
|
python-2.7.15
|
||||||
|
|
||||||
Runtime options include:
|
Runtime options include:
|
||||||
|
|
||||||
- `python-2.7.13`
|
- `python-3.7.0`
|
||||||
- `python-3.6.0`
|
- `python-3.6.6`
|
||||||
- `pypy-5.6.0` (unsupported, experimental)
|
- `python-2.7.15`
|
||||||
- `pypy3-5.5.0` (unsupported, experimental)
|
|
||||||
|
|||||||
+285
-153
@@ -15,248 +15,380 @@
|
|||||||
# Fail fast and fail hard.
|
# Fail fast and fail hard.
|
||||||
set -eo pipefail
|
set -eo pipefail
|
||||||
|
|
||||||
|
# Boostrap the Buildpack Standard Library.
|
||||||
|
export BPLOG_PREFIX="buildpack.python"
|
||||||
|
export BUILDPACK_LOG_FILE=${BUILDPACK_LOG_FILE:-/dev/null}
|
||||||
|
|
||||||
[ "$BUILDPACK_XTRACE" ] && set -o xtrace
|
[ "$BUILDPACK_XTRACE" ] && set -o xtrace
|
||||||
|
|
||||||
# Prepend proper path for virtualenv hackery. This will be deprecated soon.
|
# Prepend proper path for old-school virtualenv hackery.
|
||||||
|
# This may not be neccessary.
|
||||||
export PATH=:/usr/local/bin:$PATH
|
export PATH=:/usr/local/bin:$PATH
|
||||||
|
|
||||||
# Paths.
|
# Setup Path variables, for later use in the Buildpack.
|
||||||
BIN_DIR=$(cd $(dirname $0); pwd) # absolute path
|
BIN_DIR=$(cd "$(dirname "$0")"; pwd) # absolute path
|
||||||
ROOT_DIR=$(dirname $BIN_DIR)
|
ROOT_DIR=$(dirname "$BIN_DIR")
|
||||||
BUILD_DIR=$1
|
BUILD_DIR=$1
|
||||||
CACHE_DIR=$2
|
CACHE_DIR=$2
|
||||||
ENV_DIR=$3
|
ENV_DIR=$3
|
||||||
|
|
||||||
# Static configurations for virtualenv caches.
|
# Export Path variables, for use in sub-scripts.
|
||||||
VIRTUALENV_LOC=".heroku/venv"
|
export BUILD_DIR CACHE_DIR ENV_DIR
|
||||||
LEGACY_TRIGGER="lib/python2.7"
|
|
||||||
|
|
||||||
DEFAULT_PYTHON_VERSION="python-2.7.13"
|
# Set the Buildpack's internet target for downloading Python distributions.
|
||||||
|
# The user can provide BUILDPACK_VENDOR_URL to specify a custom target.
|
||||||
|
# Note: this is designed for non-Heroku use, as it does not use the user-provided
|
||||||
|
# environment variable mechanism (the ENV_DIR).
|
||||||
|
VENDOR_URL="https://lang-python.s3.amazonaws.com/$STACK"
|
||||||
|
if [[ -n ${BUILDPACK_VENDOR_URL:-} ]]; then
|
||||||
|
VENDOR_URL="$BUILDPACK_VENDOR_URL"
|
||||||
|
fi
|
||||||
|
export VENDOR_URL
|
||||||
|
|
||||||
|
# Which versions of Python are we using?
|
||||||
|
# These variables are used to specify which versions of Python to install by default,
|
||||||
|
# as well as prompt the user to upgrade if they are using an un–supported version.
|
||||||
|
# Note: When 3.7 lands, I recommend switching to LATEST_36 and LATEST_37.
|
||||||
|
DEFAULT_PYTHON_VERSION="python-3.6.6"
|
||||||
|
LATEST_36="python-3.6.6"
|
||||||
|
LATEST_37="python-3.7.0"
|
||||||
|
LATEST_35="python-3.5.6"
|
||||||
|
LATEST_34="python-3.4.9"
|
||||||
|
LATEST_27="python-2.7.15"
|
||||||
|
|
||||||
|
# Supported Python Branches
|
||||||
|
PY37="python-3.7"
|
||||||
|
PY36="python-3.6"
|
||||||
|
PY35="python-3.5"
|
||||||
|
PY34="python-3.4"
|
||||||
|
PY27="python-2.7"
|
||||||
|
|
||||||
|
# Which stack is used (for binary downloading), if none is provided (e.g. outside of Heroku)?
|
||||||
DEFAULT_PYTHON_STACK="cedar-14"
|
DEFAULT_PYTHON_STACK="cedar-14"
|
||||||
PYTHON_EXE="/app/.heroku/python/bin/python"
|
# If pip doesn't match this version (the version we install), run the installer.
|
||||||
PIP_VERSION="9.0.1"
|
PIP_UPDATE="9.0.2"
|
||||||
SETUPTOOLS_VERSION="32.1.0"
|
|
||||||
|
|
||||||
# Common Problem Warnings
|
export DEFAULT_PYTHON_VERSION DEFAULT_PYTHON_STACK PIP_UPDATE
|
||||||
export WARNINGS_LOG=$(mktemp)
|
export LATEST_27 LATEST_36 LATEST_37 LATEST_35 LATEST_34
|
||||||
|
export PY37 PY36 PY35 PY27 PY34
|
||||||
|
|
||||||
|
# Common Problem Warnings:
|
||||||
|
# This section creates a temporary file in which to stick the output of `pip install`.
|
||||||
|
# The `warnings` subscript then greps through this for common problems and guides
|
||||||
|
# the user towards resolution of known issues.
|
||||||
|
WARNINGS_LOG=$(mktemp)
|
||||||
|
export WARNINGS_LOG
|
||||||
export RECOMMENDED_PYTHON_VERSION=$DEFAULT_PYTHON_VERSION
|
export RECOMMENDED_PYTHON_VERSION=$DEFAULT_PYTHON_VERSION
|
||||||
|
|
||||||
# Setup bpwatch
|
# The buildpack ships with a few executable tools (e.g. pip-grep, etc).
|
||||||
export PATH=$PATH:$ROOT_DIR/vendor/:$ROOT_DIR/vendor/bpwatch
|
# This installs them into the path, so we can execute them directly.
|
||||||
LOGPLEX_KEY="t.b90d9d29-5388-4908-9737-b4576af1d4ce"
|
export PATH=$PATH:$ROOT_DIR/vendor/:$ROOT_DIR/vendor/pip-pop
|
||||||
export BPWATCH_STORE_PATH=$CACHE_DIR/bpwatch.json
|
|
||||||
BUILDPACK_VERSION=v28
|
|
||||||
|
|
||||||
# Setup pip-pop (pip-diff)
|
# Set environment variables if they weren't set by the platform.
|
||||||
export PATH=$PATH:$ROOT_DIR/vendor/pip-pop
|
# Note: this is legacy, for a deprecated build system known as Anvil.
|
||||||
|
# This can likely be removed, with caution.
|
||||||
# Support Anvil Build_IDs
|
|
||||||
[ ! "$SLUG_ID" ] && SLUG_ID="defaultslug"
|
[ ! "$SLUG_ID" ] && SLUG_ID="defaultslug"
|
||||||
[ ! "$REQUEST_ID" ] && REQUEST_ID=$SLUG_ID
|
[ ! "$REQUEST_ID" ] && REQUEST_ID=$SLUG_ID
|
||||||
[ ! "$STACK" ] && STACK=$DEFAULT_PYTHON_STACK
|
[ ! "$STACK" ] && STACK=$DEFAULT_PYTHON_STACK
|
||||||
|
|
||||||
# Sanitizing environment variables.
|
# Sanitize externally-provided environment variables:
|
||||||
|
# The following environment variables are either problematic or simply unneccessary
|
||||||
|
# for the buildpack to have knowledge of, so we unset them, to keep the environment
|
||||||
|
# as clean and pristine as possible.
|
||||||
unset GIT_DIR PYTHONHOME PYTHONPATH
|
unset GIT_DIR PYTHONHOME PYTHONPATH
|
||||||
unset RECEIVE_DATA RUN_KEY BUILD_INFO DEPLOY LOG_TOKEN DYNO
|
unset RECEIVE_DATA RUN_KEY BUILD_INFO DEPLOY LOG_TOKEN
|
||||||
unset CYTOKINE_LOG_FILE GEM_PATH
|
unset CYTOKINE_LOG_FILE GEM_PATH
|
||||||
|
|
||||||
# Setup buildpack instrumentation.
|
# Import the utils script, which contains helper functions used throughout the buildpack.
|
||||||
bpwatch init $LOGPLEX_KEY
|
# shellcheck source=bin/utils
|
||||||
bpwatch build python $BUILDPACK_VERSION $REQUEST_ID
|
source "$BIN_DIR/utils"
|
||||||
|
|
||||||
bpwatch start compile
|
# Import the warnings script, which contains the `pip install` user warning mechanisms
|
||||||
|
# (mentioned and explained above)
|
||||||
|
# shellcheck source=bin/warnings
|
||||||
|
source "$BIN_DIR/warnings"
|
||||||
|
|
||||||
# Syntax sugar.
|
# Make the directory in which we will create symlinks from the temporary build directory
|
||||||
source $BIN_DIR/utils
|
# to `/app`.
|
||||||
|
# Symlinks are required, since Python is not a portable installation.
|
||||||
# Import collection of warnings.
|
# More on this topic later.
|
||||||
source $BIN_DIR/warnings
|
|
||||||
|
|
||||||
# we need to put a bunch of symlinks in there later
|
|
||||||
mkdir -p /app/.heroku
|
mkdir -p /app/.heroku
|
||||||
|
|
||||||
# Set up outputs under new context
|
# This buildpack programatically generates (or simply copies) a number of files for
|
||||||
|
# buildpack machinery: an export script, and a number of `.profile.d` scripts. This
|
||||||
|
# section declares the locations of those files and targets.
|
||||||
PROFILE_PATH="$BUILD_DIR/.profile.d/python.sh"
|
PROFILE_PATH="$BUILD_DIR/.profile.d/python.sh"
|
||||||
EXPORT_PATH="$BIN_DIR/../export"
|
EXPORT_PATH="$BIN_DIR/../export"
|
||||||
GUNICORN_PROFILE_PATH="$BUILD_DIR/.profile.d/python.gunicorn.sh"
|
GUNICORN_PROFILE_PATH="$BUILD_DIR/.profile.d/python.gunicorn.sh"
|
||||||
|
WEB_CONCURRENCY_PROFILE_PATH="$BUILD_DIR/.profile.d/WEB_CONCURRENCY.sh"
|
||||||
|
|
||||||
# We'll need to send these statics to other scripts we `source`.
|
# We'll need to send these statics to other scripts we `source`.
|
||||||
export BUILD_DIR CACHE_DIR BIN_DIR PROFILE_PATH EXPORT_PATH
|
export BUILD_DIR CACHE_DIR BIN_DIR PROFILE_PATH EXPORT_PATH
|
||||||
|
|
||||||
# Prepend proper environment variables for Python use.
|
# Python Environment Variables
|
||||||
|
# Set Python-specific environment variables, for running Python within the buildpack.
|
||||||
|
# Notes on each variable included.
|
||||||
|
|
||||||
|
# PATH is relatively obvious, we need to be able to execute 'python'.
|
||||||
export PATH=/app/.heroku/python/bin:/app/.heroku/vendor/bin:$PATH
|
export PATH=/app/.heroku/python/bin:/app/.heroku/vendor/bin:$PATH
|
||||||
|
# Tell Python to not buffer it's stdin/stdout.
|
||||||
export PYTHONUNBUFFERED=1
|
export PYTHONUNBUFFERED=1
|
||||||
|
# Set the locale to a well-known and expected standard.
|
||||||
export LANG=en_US.UTF-8
|
export LANG=en_US.UTF-8
|
||||||
|
# `~/.heroku/vendor` is an place where the buildpack may stick pre-build binaries for known
|
||||||
|
# C dependencies (e.g. libmemcached on cedar-14). This section configures Python (GCC, more specifically)
|
||||||
|
# and pip to automatically include these paths when building binaries.
|
||||||
export C_INCLUDE_PATH=/app/.heroku/vendor/include:/app/.heroku/python/include:$C_INCLUDE_PATH
|
export C_INCLUDE_PATH=/app/.heroku/vendor/include:/app/.heroku/python/include:$C_INCLUDE_PATH
|
||||||
export CPLUS_INCLUDE_PATH=/app/.heroku/vendor/include:/app/.heroku/python/include:$CPLUS_INCLUDE_PATH
|
export CPLUS_INCLUDE_PATH=/app/.heroku/vendor/include:/app/.heroku/python/include:$CPLUS_INCLUDE_PATH
|
||||||
export LIBRARY_PATH=/app/.heroku/vendor/lib:/app/.heroku/python/lib:$LIBRARY_PATH
|
export LIBRARY_PATH=/app/.heroku/vendor/lib:/app/.heroku/python/lib:$LIBRARY_PATH
|
||||||
export LD_LIBRARY_PATH=/app/.heroku/vendor/lib:/app/.heroku/python/lib:$LD_LIBRARY_PATH
|
export LD_LIBRARY_PATH=/app/.heroku/vendor/lib:/app/.heroku/python/lib:$LD_LIBRARY_PATH
|
||||||
export PKG_CONFIG_PATH=/app/.heroku/vendor/lib/pkg-config:/app/.heroku/python/lib/pkg-config:$PKG_CONFIG_PATH
|
export PKG_CONFIG_PATH=/app/.heroku/vendor/lib/pkg-config:/app/.heroku/python/lib/pkg-config:$PKG_CONFIG_PATH
|
||||||
|
|
||||||
|
# The Application Code
|
||||||
|
# --------------------
|
||||||
|
|
||||||
# Switch to the repo's context.
|
# Switch to the repo's context.
|
||||||
cd $BUILD_DIR
|
cd "$BUILD_DIR"
|
||||||
|
|
||||||
# Warn for lack of Procfile.
|
# The Cache
|
||||||
if [[ ! -f Procfile ]]; then
|
# ---------
|
||||||
puts-warn 'Warning: Your application is missing a Procfile. This file tells Heroku how to run your application.'
|
|
||||||
puts-warn 'Learn more: https://devcenter.heroku.com/articles/procfile'
|
# The workflow for the Python Buildpack's cache is as follows:
|
||||||
|
#
|
||||||
|
# - `~/.heroku/{known-paths}` are copied from the cache into the slug.
|
||||||
|
# - The build is executed, modifying `~/.heroku/{known-paths}`.
|
||||||
|
# - Once the build is complete, `~/.heroku/{known-paths}` is copied back into the cache.
|
||||||
|
|
||||||
|
# Create the cache directory, if it doesn't exist.
|
||||||
|
mkdir -p "$CACHE_DIR"
|
||||||
|
|
||||||
|
# Restore old artifacts from the cache.
|
||||||
|
mkdir -p .heroku
|
||||||
|
|
||||||
|
# The Python installation.
|
||||||
|
cp -R "$CACHE_DIR/.heroku/python" .heroku/ &> /dev/null || true
|
||||||
|
# A plain text file which contains the current stack being used (used for cache busting).
|
||||||
|
cp -R "$CACHE_DIR/.heroku/python-stack" .heroku/ &> /dev/null || true
|
||||||
|
# A plain text file which contains the current python version being used (used for cache busting).
|
||||||
|
cp -R "$CACHE_DIR/.heroku/python-version" .heroku/ &> /dev/null || true
|
||||||
|
# A plain text file which contains the current sqlite3 version being used (used for cache busting).
|
||||||
|
cp -R "$CACHE_DIR/.heroku/python-sqlite3-version" .heroku/ &> /dev/null || true
|
||||||
|
# Any pre-compiled binaries, provided by the buildpack.
|
||||||
|
cp -R "$CACHE_DIR/.heroku/vendor" .heroku/ &> /dev/null || true
|
||||||
|
# "editable" installations of code repositories, via pip or pipenv.
|
||||||
|
if [[ -d "$CACHE_DIR/.heroku/src" ]]; then
|
||||||
|
cp -R "$CACHE_DIR/.heroku/src" .heroku/ &> /dev/null || true
|
||||||
fi
|
fi
|
||||||
|
|
||||||
# Experimental pre_compile hook.
|
# The pre_compile hook. Customers rely on this. Don't remove it.
|
||||||
bpwatch start pre_compile
|
# This part of the code is used to allow users to customize their build experience
|
||||||
source $BIN_DIR/steps/hooks/pre_compile
|
# without forking the buildpack by providing a `bin/pre_compile` script, which gets
|
||||||
bpwatch stop pre_compile
|
# run inline with the buildpack automatically.
|
||||||
|
|
||||||
# Sticky runtimes.
|
# shellcheck source=bin/steps/hooks/pre_compile
|
||||||
if [ -f $CACHE_DIR/.heroku/python-version ]; then
|
source "$BIN_DIR/steps/hooks/pre_compile"
|
||||||
DEFAULT_PYTHON_VERSION=$(cat $CACHE_DIR/.heroku/python-version)
|
|
||||||
|
# Sticky runtimes. If there was a previous build, and it used a given version of Python,
|
||||||
|
# continue to use that version of Python in perpituity (warnings will be raised if
|
||||||
|
# they are out–of–date).
|
||||||
|
if [ -f "$CACHE_DIR/.heroku/python-version" ]; then
|
||||||
|
DEFAULT_PYTHON_VERSION=$(cat "$CACHE_DIR/.heroku/python-version")
|
||||||
fi
|
fi
|
||||||
|
|
||||||
# Stack fallback for non-declared caches.
|
# We didn't always record the stack version. This code is in place because of that.
|
||||||
if [ -f $CACHE_DIR/.heroku/python-stack ]; then
|
if [ -f "$CACHE_DIR/.heroku/python-stack" ]; then
|
||||||
CACHED_PYTHON_STACK=$(cat $CACHE_DIR/.heroku/python-stack)
|
CACHED_PYTHON_STACK=$(cat "$CACHE_DIR/.heroku/python-stack")
|
||||||
else
|
else
|
||||||
CACHED_PYTHON_STACK=$STACK
|
CACHED_PYTHON_STACK=$STACK
|
||||||
fi
|
fi
|
||||||
|
|
||||||
# Pipenv Python version support.
|
export CACHED_PYTHON_STACK
|
||||||
source $BIN_DIR/steps/pipenv-python-version
|
|
||||||
|
|
||||||
# If no runtime given, assume default version.
|
# Pipenv Python version support.
|
||||||
|
# Detect the version of Python requested from a Pipfile (e.g. python_version or python_full_version).
|
||||||
|
# Convert it to a runtime.txt file.
|
||||||
|
|
||||||
|
# shellcheck source=bin/steps/pipenv-python-version
|
||||||
|
source "$BIN_DIR/steps/pipenv-python-version"
|
||||||
|
|
||||||
|
# If no runtime was provided by the user, assume the default Python runtime version.
|
||||||
if [ ! -f runtime.txt ]; then
|
if [ ! -f runtime.txt ]; then
|
||||||
echo $DEFAULT_PYTHON_VERSION > runtime.txt
|
echo "$DEFAULT_PYTHON_VERSION" > runtime.txt
|
||||||
fi
|
fi
|
||||||
|
|
||||||
# Prepare the cache.
|
# Create the directory for .profile.d, if it doesn't exist.
|
||||||
mkdir -p $CACHE_DIR
|
mkdir -p "$(dirname "$PROFILE_PATH")"
|
||||||
|
# Create the directory for editable source code installation, if it doesn't exist.
|
||||||
# Purge "old-style" virtualenvs.
|
|
||||||
bpwatch start clear_old_venvs
|
|
||||||
[ -d $CACHE_DIR/$LEGACY_TRIGGER ] && rm -fr $CACHE_DIR/.heroku/bin $CACHE_DIR/.heroku/lib $CACHE_DIR/.heroku/include
|
|
||||||
[ -d $CACHE_DIR/$VIRTUALENV_LOC ] && rm -fr $CACHE_DIR/.heroku/venv $CACHE_DIR/.heroku/src
|
|
||||||
bpwatch stop clear_old_venvs
|
|
||||||
|
|
||||||
# Restore old artifacts from the cache.
|
|
||||||
bpwatch start restore_cache
|
|
||||||
mkdir -p .heroku
|
|
||||||
|
|
||||||
cp -R $CACHE_DIR/.heroku/python .heroku/ &> /dev/null || true
|
|
||||||
cp -R $CACHE_DIR/.heroku/python-stack .heroku/ &> /dev/null || true
|
|
||||||
cp -R $CACHE_DIR/.heroku/python-version .heroku/ &> /dev/null || true
|
|
||||||
cp -R $CACHE_DIR/.heroku/vendor .heroku/ &> /dev/null || true
|
|
||||||
cp -R $CACHE_DIR/.heroku/venv .heroku/ &> /dev/null || true
|
|
||||||
if [[ -d $CACHE_DIR/.heroku/src ]]; then
|
|
||||||
cp -R $CACHE_DIR/.heroku/src .heroku/ &> /dev/null || true
|
|
||||||
fi
|
|
||||||
|
|
||||||
bpwatch stop restore_cache
|
|
||||||
|
|
||||||
mkdir -p $(dirname $PROFILE_PATH)
|
|
||||||
mkdir -p /app/.heroku/src
|
mkdir -p /app/.heroku/src
|
||||||
|
|
||||||
|
# On Heroku CI, builds happen in `/app`. Otherwise, on the Heroku platform,
|
||||||
|
# they occur in a temp directory. Beacuse Python is not portable, we must create
|
||||||
|
# symlinks to emulate that we are operating in `/app` during the build process.
|
||||||
|
# This is (hopefully obviously) because apps end up running from `/app` in production.
|
||||||
if [[ $BUILD_DIR != '/app' ]]; then
|
if [[ $BUILD_DIR != '/app' ]]; then
|
||||||
# python expects to reside in /app, so set up symlinks
|
# python expects to reside in /app, so set up symlinks
|
||||||
# we will not remove these later so subsequent buildpacks can still invoke it
|
# we will not remove these later so subsequent buildpacks can still invoke it
|
||||||
ln -nsf $BUILD_DIR/.heroku/python /app/.heroku/python
|
ln -nsf "$BUILD_DIR/.heroku/python" /app/.heroku/python
|
||||||
ln -nsf $BUILD_DIR/.heroku/vendor /app/.heroku/vendor
|
ln -nsf "$BUILD_DIR/.heroku/vendor" /app/.heroku/vendor
|
||||||
ln -nsf $BUILD_DIR/.heroku/venv /app/.heroku/venv
|
|
||||||
# Note: .heroku/src is copied in later.
|
# Note: .heroku/src is copied in later.
|
||||||
fi
|
fi
|
||||||
|
|
||||||
# Install Python.
|
# Download / Install Python, from pre-build binaries available on Amazon S3.
|
||||||
source $BIN_DIR/steps/python
|
# This step also bootstraps pip / setuptools.
|
||||||
|
(( start=$(nowms) ))
|
||||||
|
# shellcheck source=bin/steps/python
|
||||||
|
source "$BIN_DIR/steps/python"
|
||||||
|
mtime "python.install.time" "${start}"
|
||||||
|
|
||||||
# Sanity check for setuptools/distribute.
|
# Install Pipenv dependencies, if a Pipfile was provided.
|
||||||
source $BIN_DIR/steps/setuptools
|
# shellcheck source=bin/steps/pipenv
|
||||||
|
source "$BIN_DIR/steps/pipenv"
|
||||||
|
|
||||||
# Pipenv support.
|
# Uninstall removed dependencies with Pip.
|
||||||
source $BIN_DIR/steps/pipenv
|
# The buildpack will automatically remove any declared dependencies (in requirements.txt)
|
||||||
|
# that were explicitly removed. This machinery is a bit complex, but it is not complicated.
|
||||||
|
(( start=$(nowms) ))
|
||||||
|
# shellcheck source=bin/steps/pip-uninstall
|
||||||
|
source "$BIN_DIR/steps/pip-uninstall"
|
||||||
|
mtime "pip.uninstall.time" "${start}"
|
||||||
|
|
||||||
# If no requirements.txt file given, assume `setup.py develop` is intended.
|
# If no requirements.txt file given, assume `setup.py develop` is intended.
|
||||||
if [ ! -f requirements.txt ]; then
|
# This allows for people to ship a setup.py application to Heroku
|
||||||
|
# (which is rare, but I vouch that it should work!)
|
||||||
|
|
||||||
|
if [ ! -f requirements.txt ] && [ ! -f Pipfile ]; then
|
||||||
echo "-e ." > requirements.txt
|
echo "-e ." > requirements.txt
|
||||||
fi
|
fi
|
||||||
|
|
||||||
# Uninstall removed dependencies with Pip.
|
# Fix egg-links.
|
||||||
source $BIN_DIR/steps/pip-uninstall
|
# Because we're installing things into a different path than we're running them (temp dir vs app dir),
|
||||||
|
# We must re-write all of Python's eggpath links to target the proper directory.
|
||||||
|
# shellcheck source=bin/steps/eggpath-fix
|
||||||
|
source "$BIN_DIR/steps/eggpath-fix"
|
||||||
|
|
||||||
# Mercurial support.
|
# Mercurial support.
|
||||||
source $BIN_DIR/steps/mercurial
|
# If a customer appears to be using mercurial for dependency resolution, we install it first.
|
||||||
|
# Note: this only applies to pip, not pipenv. This can likely be removed, over time. Measure it first.
|
||||||
|
# shellcheck source=bin/steps/mercurial
|
||||||
|
source "$BIN_DIR/steps/mercurial"
|
||||||
|
|
||||||
# Pylibmc support.
|
# Pylibmc support.
|
||||||
source $BIN_DIR/steps/pylibmc
|
# On cedar-14, libmemcached was not available. The buildpack provides its own version, instead.
|
||||||
|
# shellcheck source=bin/steps/pylibmc
|
||||||
|
source "$BIN_DIR/steps/pylibmc"
|
||||||
|
|
||||||
# Libffi support.
|
# Support for Geo libraries. This is deprecated functionality, only functional on cedar-14.
|
||||||
source $BIN_DIR/steps/cryptography
|
# It is undocumented.
|
||||||
|
# shellcheck source=bin/steps/geo-libs
|
||||||
# Support for Geo libraries.
|
sub_env "$BIN_DIR/steps/geo-libs"
|
||||||
sub-env $BIN_DIR/steps/geo-libs
|
|
||||||
|
|
||||||
# GDAL support.
|
# GDAL support.
|
||||||
source $BIN_DIR/steps/gdal
|
# This is part of the Geo support.
|
||||||
|
# shellcheck source=bin/steps/gdal
|
||||||
|
source "$BIN_DIR/steps/gdal"
|
||||||
|
|
||||||
# Install dependencies with Pip (where the magic happens).
|
# SQLite3 support.
|
||||||
source $BIN_DIR/steps/pip-install
|
# This sets up and installs sqlite3 dev headers and the sqlite3 binary but not the
|
||||||
|
# libsqlite3-0 library since that exists on the stack image.
|
||||||
|
# Note: This only applies to Python 2.7.15+ and Python 3.6.6+
|
||||||
|
(( start=$(nowms) ))
|
||||||
|
# shellcheck source=bin/steps/sqlite3
|
||||||
|
source "$BIN_DIR/steps/sqlite3"
|
||||||
|
buildpack_sqlite3_install
|
||||||
|
mtime "sqlite3.install.time" "${start}"
|
||||||
|
|
||||||
|
# pip install
|
||||||
|
# -----------
|
||||||
|
|
||||||
|
# Install dependencies with pip (where the magic happens).
|
||||||
|
(( start=$(nowms) ))
|
||||||
|
# shellcheck source=bin/steps/pip-install
|
||||||
|
source "$BIN_DIR/steps/pip-install"
|
||||||
|
mtime "pip.install.time" "${start}"
|
||||||
|
|
||||||
# Support for NLTK corpora.
|
# Support for NLTK corpora.
|
||||||
sub-env $BIN_DIR/steps/nltk
|
# Note: this may only work on Python 2.7. I don't think many customers use this functionality,
|
||||||
|
# and it should probably be undocumented.
|
||||||
|
# (there's an import error on 3.6 that should hopefully be fixed upstream at some point)
|
||||||
|
(( start=$(nowms) ))
|
||||||
|
sub_env "$BIN_DIR/steps/nltk"
|
||||||
|
mtime "nltk.download.time" "${start}"
|
||||||
|
|
||||||
|
# Support for editable installations. Here, we are copying pip–created src directory,
|
||||||
|
# and copying it into the proper place (the logical place to do this was early, but it must be done here).
|
||||||
|
# In CI, $BUILD_DIR is /app.
|
||||||
|
if [[ ! "$BUILD_DIR" == "/app" ]]; then
|
||||||
|
rm -fr "$BUILD_DIR/.heroku/src"
|
||||||
|
deep-cp /app/.heroku/src "$BUILD_DIR/.heroku/src"
|
||||||
|
fi
|
||||||
|
|
||||||
# Support for pip install -e.
|
|
||||||
rm -fr $BUILD_DIR/.heroku/src
|
|
||||||
deep-cp /app/.heroku/src $BUILD_DIR/.heroku/src
|
|
||||||
|
|
||||||
# Django collectstatic support.
|
# Django collectstatic support.
|
||||||
sub-env $BIN_DIR/steps/collectstatic
|
# The buildpack automatically runs collectstatic for Django applications.
|
||||||
|
# This is the cause for the majority of build failures on the Python platform.
|
||||||
|
# These failures are intentional — if collectstatic (which can be tricky, at times) fails,
|
||||||
|
# your build fails.
|
||||||
|
(( start=$(nowms) ))
|
||||||
|
sub_env "$BIN_DIR/steps/collectstatic"
|
||||||
|
mtime "collectstatic.time" "${start}"
|
||||||
|
|
||||||
# Create .profile script for application runtime environment variables.
|
|
||||||
set-env PATH '$HOME/.heroku/python/bin:$PATH'
|
# Progamatically create .profile.d script for application runtime environment variables.
|
||||||
set-env PYTHONUNBUFFERED true
|
|
||||||
set-env PYTHONHOME /app/.heroku/python
|
# Set the PATH to include Python / pip / pipenv / etc.
|
||||||
set-env LIBRARY_PATH '/app/.heroku/vendor/lib:/app/.heroku/python/lib:$LIBRARY_PATH'
|
set_env PATH "\$HOME/.heroku/python/bin:\$PATH"
|
||||||
set-env LD_LIBRARY_PATH '/app/.heroku/vendor/lib:/app/.heroku/python/lib:$LD_LIBRARY_PATH'
|
# Tell Python to run in unbuffered mode.
|
||||||
set-default-env LANG en_US.UTF-8
|
set_env PYTHONUNBUFFERED true
|
||||||
set-default-env PYTHONHASHSEED random
|
# Tell Python where it lives.
|
||||||
set-default-env PYTHONPATH /app/
|
set_env PYTHONHOME "\$HOME/.heroku/python"
|
||||||
|
# Set variables for C libraries.
|
||||||
|
set_env LIBRARY_PATH "\$HOME/.heroku/vendor/lib:\$HOME/.heroku/python/lib:\$LIBRARY_PATH"
|
||||||
|
set_env LD_LIBRARY_PATH "\$HOME/.heroku/vendor/lib:\$HOME/.heroku/python/lib:\$LD_LIBRARY_PATH"
|
||||||
|
# Locale.
|
||||||
|
set_default_env LANG en_US.UTF-8
|
||||||
|
# The Python hash seed is set to random.
|
||||||
|
set_default_env PYTHONHASHSEED random
|
||||||
|
# Tell Python to look for Python modules in the /app dir. Don't change this.
|
||||||
|
set_default_env PYTHONPATH "\$HOME"
|
||||||
|
|
||||||
|
# Python expects to be in /app, if at runtime, it is not, set
|
||||||
|
# up symlinks… this can occur when the subdir buildpack is used.
|
||||||
|
cat <<EOT >> "$PROFILE_PATH"
|
||||||
|
if [[ \$HOME != "/app" ]]; then
|
||||||
|
mkdir -p /app/.heroku
|
||||||
|
ln -nsf "\$HOME/.heroku/python" /app/.heroku/python
|
||||||
|
ln -nsf "\$HOME/.heroku/vendor" /app/.heroku/vendor
|
||||||
|
fi
|
||||||
|
EOT
|
||||||
|
|
||||||
# Install sane-default script for $WEB_CONCURRENCY and $FORWARDED_ALLOW_IPS.
|
# Install sane-default script for $WEB_CONCURRENCY and $FORWARDED_ALLOW_IPS.
|
||||||
cp $ROOT_DIR/vendor/python.gunicorn.sh $GUNICORN_PROFILE_PATH
|
cp "$ROOT_DIR/vendor/WEB_CONCURRENCY.sh" "$WEB_CONCURRENCY_PROFILE_PATH"
|
||||||
|
cp "$ROOT_DIR/vendor/python.gunicorn.sh" "$GUNICORN_PROFILE_PATH"
|
||||||
|
|
||||||
# Experimental post_compile hook.
|
# Experimental post_compile hook. Don't remove this.
|
||||||
bpwatch start post_compile
|
# shellcheck source=bin/steps/hooks/post_compile
|
||||||
source $BIN_DIR/steps/hooks/post_compile
|
source "$BIN_DIR/steps/hooks/post_compile"
|
||||||
bpwatch stop post_compile
|
|
||||||
|
|
||||||
set +e
|
# Fix egg-links, again.
|
||||||
# rewrite build dir in egg links to /app so things are found at runtime
|
# shellcheck source=bin/steps/eggpath-fix2
|
||||||
find .heroku/python/lib/python*/site-packages/ -name "*.pth" -print0 2> /dev/null | xargs -r -0 -n 1 sed -i -e "s#$(pwd)#/app#" &> /dev/null
|
source "$BIN_DIR/steps/eggpath-fix2"
|
||||||
set -e
|
|
||||||
|
|
||||||
set +e
|
# Store new artifacts in the cache.
|
||||||
# Support for PyPy
|
rm -rf "$CACHE_DIR/.heroku/python"
|
||||||
find .heroku/python/lib-python/*/site-packages/ -name "*.pth" -print0 2> /dev/null | xargs -r -0 -n 1 sed -i -e "s#$(pwd)#/app#" &> /dev/null
|
rm -rf "$CACHE_DIR/.heroku/python-version"
|
||||||
set -e
|
rm -rf "$CACHE_DIR/.heroku/python-stack"
|
||||||
|
rm -rf "$CACHE_DIR/.heroku/vendor"
|
||||||
|
rm -rf "$CACHE_DIR/.heroku/src"
|
||||||
|
|
||||||
# Store new artifacts in cache.
|
mkdir -p "$CACHE_DIR/.heroku"
|
||||||
bpwatch start dump_cache
|
cp -R .heroku/python "$CACHE_DIR/.heroku/"
|
||||||
|
cp -R .heroku/python-version "$CACHE_DIR/.heroku/"
|
||||||
|
cp -R .heroku/python-stack "$CACHE_DIR/.heroku/" &> /dev/null || true
|
||||||
|
cp -R .heroku/vendor "$CACHE_DIR/.heroku/" &> /dev/null || true
|
||||||
|
if [[ -d .heroku/src ]]; then
|
||||||
|
cp -R .heroku/src "$CACHE_DIR/.heroku/" &> /dev/null || true
|
||||||
|
fi
|
||||||
|
|
||||||
rm -rf $CACHE_DIR/.heroku/python
|
# Measure the size of the Python installation.
|
||||||
rm -rf $CACHE_DIR/.heroku/python-version
|
# shellcheck disable=SC2119
|
||||||
rm -rf $CACHE_DIR/.heroku/python-stack
|
mmeasure 'python.size' "$(measure-size)"
|
||||||
rm -rf $CACHE_DIR/.heroku/vendor
|
|
||||||
rm -rf $CACHE_DIR/.heroku/venv
|
|
||||||
rm -rf $CACHE_DIR/.heroku/src
|
|
||||||
|
|
||||||
mkdir -p $CACHE_DIR/.heroku
|
|
||||||
cp -R .heroku/python $CACHE_DIR/.heroku/
|
|
||||||
cp -R .heroku/python-version $CACHE_DIR/.heroku/
|
|
||||||
cp -R .heroku/python-stack $CACHE_DIR/.heroku/ &> /dev/null || true
|
|
||||||
cp -R .heroku/vendor $CACHE_DIR/.heroku/ &> /dev/null || true
|
|
||||||
cp -R .heroku/venv $CACHE_DIR/.heroku/ &> /dev/null || true
|
|
||||||
if [[ -d .heroku/src ]]; then
|
|
||||||
cp -R .heroku/src $CACHE_DIR/.heroku/ &> /dev/null || true
|
|
||||||
fi
|
|
||||||
|
|
||||||
bpwatch stop dump_cache
|
|
||||||
|
|
||||||
# Fin.
|
|
||||||
bpwatch stop compile
|
|
||||||
|
|||||||
+1
-1
@@ -15,7 +15,7 @@
|
|||||||
BUILD_DIR=$1
|
BUILD_DIR=$1
|
||||||
|
|
||||||
# Exit early if app is clearly not Python.
|
# Exit early if app is clearly not Python.
|
||||||
if [ ! -f $BUILD_DIR/requirements.txt ] && [ ! -f $BUILD_DIR/setup.py ] && [ ! -f $BUILD_DIR/Pipfile ]; then
|
if [ ! -f "$BUILD_DIR/requirements.txt" ] && [ ! -f "$BUILD_DIR/setup.py" ] && [ ! -f "$BUILD_DIR/Pipfile" ]; then
|
||||||
exit 1
|
exit 1
|
||||||
fi
|
fi
|
||||||
|
|
||||||
|
|||||||
+1
-2
@@ -1,10 +1,9 @@
|
|||||||
#!/usr/bin/env bash
|
#!/usr/bin/env bash
|
||||||
# bin/release <build-dir>
|
# bin/release <build-dir>
|
||||||
|
|
||||||
BIN_DIR=$(cd $(dirname $0); pwd) # absolute path
|
|
||||||
BUILD_DIR=$1
|
BUILD_DIR=$1
|
||||||
|
|
||||||
MANAGE_FILE=$(cd $BUILD_DIR && find . -maxdepth 3 -type f -name 'manage.py' | head -1)
|
MANAGE_FILE=$(cd "$BUILD_DIR" && find . -maxdepth 3 -type f -name 'manage.py' | head -1)
|
||||||
MANAGE_FILE=${MANAGE_FILE:2}
|
MANAGE_FILE=${MANAGE_FILE:2}
|
||||||
|
|
||||||
cat <<EOF
|
cat <<EOF
|
||||||
|
|||||||
+28
-8
@@ -10,7 +10,8 @@
|
|||||||
# - $DISABLE_COLLECTSTATIC: disables this functionality.
|
# - $DISABLE_COLLECTSTATIC: disables this functionality.
|
||||||
# - $DEBUG_COLLECTSTATIC: upon failure, print out environment variables.
|
# - $DEBUG_COLLECTSTATIC: upon failure, print out environment variables.
|
||||||
|
|
||||||
source $BIN_DIR/utils
|
# shellcheck source=bin/utils
|
||||||
|
source "$BIN_DIR/utils"
|
||||||
|
|
||||||
# Location of 'manage.py', if it exists.
|
# Location of 'manage.py', if it exists.
|
||||||
MANAGE_FILE=$(find . -maxdepth 3 -type f -name 'manage.py' -printf '%d\t%P\n' | sort -nk1 | cut -f2 | head -1)
|
MANAGE_FILE=$(find . -maxdepth 3 -type f -name 'manage.py' -printf '%d\t%P\n' | sort -nk1 | cut -f2 | head -1)
|
||||||
@@ -20,23 +21,44 @@ MANAGE_FILE=${MANAGE_FILE:-fakepath}
|
|||||||
[ -f .heroku/collectstatic_disabled ] && DISABLE_COLLECTSTATIC=1
|
[ -f .heroku/collectstatic_disabled ] && DISABLE_COLLECTSTATIC=1
|
||||||
|
|
||||||
# Ensure that Django is explicitly specified in requirements.txt
|
# Ensure that Django is explicitly specified in requirements.txt
|
||||||
pip-grep -s requirements.txt django Django && DJANGO_INSTALLED=1
|
sp-grep -s django && DJANGO_INSTALLED=1
|
||||||
|
|
||||||
bpwatch start collectstatic # metrics collection
|
|
||||||
|
|
||||||
if [ ! "$DISABLE_COLLECTSTATIC" ] && [ -f "$MANAGE_FILE" ] && [ "$DJANGO_INSTALLED" ]; then
|
if [ ! "$DISABLE_COLLECTSTATIC" ] && [ -f "$MANAGE_FILE" ] && [ "$DJANGO_INSTALLED" ]; then
|
||||||
set +e
|
set +e
|
||||||
|
|
||||||
puts-cmd "python $MANAGE_FILE collectstatic --noinput"
|
puts-step "$ python $MANAGE_FILE collectstatic --noinput"
|
||||||
|
|
||||||
# Run collectstatic, cleanup some of the noisy output.
|
# Run collectstatic, cleanup some of the noisy output.
|
||||||
python $MANAGE_FILE collectstatic --noinput --traceback 2>&1 | sed '/^Post-processed/d;/^Copying/d;/^$/d' | indent
|
PYTHONPATH=${PYTHONPATH:-.}
|
||||||
|
export PYTHONPATH
|
||||||
|
|
||||||
|
# Create a temporary file for collecting the collectstaic logs.
|
||||||
|
COLLECTSTATIC_LOG=$(mktemp)
|
||||||
|
|
||||||
|
python "$MANAGE_FILE" collectstatic --noinput --traceback 2>&1 | tee "$COLLECTSTATIC_LOG" | sed '/^Post-processed/d;/^Copying/d;/^$/d' | indent
|
||||||
COLLECTSTATIC_STATUS="${PIPESTATUS[0]}"
|
COLLECTSTATIC_STATUS="${PIPESTATUS[0]}"
|
||||||
|
|
||||||
set -e
|
set -e
|
||||||
|
|
||||||
# Display a warning if collectstatic failed.
|
# Display a warning if collectstatic failed.
|
||||||
[ $COLLECTSTATIC_STATUS -ne 0 ] && {
|
[ "$COLLECTSTATIC_STATUS" -ne 0 ] && {
|
||||||
|
|
||||||
|
if grep -q 'SyntaxError' "$COLLECTSTATIC_LOG"; then
|
||||||
|
mcount "failure.collectstatic.syntax-error"
|
||||||
|
|
||||||
|
elif grep -q 'ImproperlyConfigured' "$COLLECTSTATIC_LOG"; then
|
||||||
|
mcount "failure.collectstatic.improper-configuration"
|
||||||
|
|
||||||
|
elif grep -q 'The CSS file' "$COLLECTSTATIC_LOG"; then
|
||||||
|
mcount "failure.collectstatic.fancy-references"
|
||||||
|
|
||||||
|
elif grep -q 'OSError' "$COLLECTSTATIC_LOG"; then
|
||||||
|
mcount "failure.collectstatic.missing-file"
|
||||||
|
|
||||||
|
else
|
||||||
|
mcount "failure.collectstatic.other"
|
||||||
|
fi
|
||||||
|
|
||||||
echo
|
echo
|
||||||
echo " ! Error while running '$ python $MANAGE_FILE collectstatic --noinput'."
|
echo " ! Error while running '$ python $MANAGE_FILE collectstatic --noinput'."
|
||||||
@@ -63,5 +85,3 @@ if [ ! "$DISABLE_COLLECTSTATIC" ] && [ -f "$MANAGE_FILE" ] && [ "$DJANGO_INSTALL
|
|||||||
|
|
||||||
echo
|
echo
|
||||||
fi
|
fi
|
||||||
|
|
||||||
bpwatch stop collectstatic # metrics collection
|
|
||||||
|
|||||||
@@ -1,35 +0,0 @@
|
|||||||
#!/usr/bin/env bash
|
|
||||||
|
|
||||||
# This script serves as the Cryptography build step of the
|
|
||||||
# [**Python Buildpack**](https://github.com/heroku/heroku-buildpack-python)
|
|
||||||
# compiler.
|
|
||||||
#
|
|
||||||
# A [buildpack](https://devcenter.heroku.com/articles/buildpacks) is an
|
|
||||||
# adapter between a Python application and Heroku's runtime.
|
|
||||||
#
|
|
||||||
# This script is invoked by [`bin/compile`](/).
|
|
||||||
|
|
||||||
# The location of the pre-compiled libffi binary.
|
|
||||||
VENDORED_LIBFFI="https://lang-python.s3.amazonaws.com/$STACK/libraries/vendor/libffi.tar.gz"
|
|
||||||
|
|
||||||
PKG_CONFIG_PATH="/app/.heroku/vendor/lib/pkgconfig:$PKG_CONFIG_PATH"
|
|
||||||
|
|
||||||
# Syntax sugar.
|
|
||||||
source $BIN_DIR/utils
|
|
||||||
|
|
||||||
bpwatch start libffi_install
|
|
||||||
|
|
||||||
# If a package using cffi exists within requirements, use vendored libffi.
|
|
||||||
if (pip-grep -s requirements.txt argon2-cffi bcrypt cffi cryptography django[argon2] Django[argon2] django[bcrypt] Django[bcrypt] PyNaCl pyOpenSSL PyOpenSSL requests[security] misaka &> /dev/null) then
|
|
||||||
|
|
||||||
if [ ! -d ".heroku/vendor/lib/libffi-3.1" ]; then
|
|
||||||
echo "-----> Noticed cffi. Bootstrapping libffi."
|
|
||||||
mkdir -p .heroku/vendor
|
|
||||||
# Download and extract libffi into target vendor directory.
|
|
||||||
curl $VENDORED_LIBFFI -s | tar zxv -C .heroku/vendor &> /dev/null
|
|
||||||
fi
|
|
||||||
|
|
||||||
export LIBFFI=$(pwd)/vendor
|
|
||||||
fi
|
|
||||||
|
|
||||||
bpwatch stop libffi_install
|
|
||||||
@@ -0,0 +1,13 @@
|
|||||||
|
#!/usr/bin/env bash
|
||||||
|
|
||||||
|
set +e
|
||||||
|
# delete any existing egg links, to uninstall exisisting installations.
|
||||||
|
find .heroku/python/lib/python*/site-packages/ -name "*.egg-link" -delete 2> /dev/null
|
||||||
|
find .heroku/python/lib/python*/site-packages/ -name "*.pth" -print0 2> /dev/null | xargs -r -0 -n 1 sed -i -e "s#/app/#/$(pwd)/#" &> /dev/null
|
||||||
|
set -e
|
||||||
|
|
||||||
|
set +e
|
||||||
|
# Support for the above, for PyPy.
|
||||||
|
find .heroku/python/lib-python/*/site-packages/ -name "*.egg-link" -print0 2> /dev/null | xargs -r -0 -n 1 sed -i -e "s#/app/#$(pwd)/#" &> /dev/null
|
||||||
|
find .heroku/python/lib-python/*/site-packages/ -name "*.pth" -print0 2> /dev/null | xargs -r -0 -n 1 sed -i -e "s#/app/#/$(pwd)/#" &> /dev/null
|
||||||
|
set -e
|
||||||
@@ -0,0 +1,10 @@
|
|||||||
|
#!/usr/bin/env bash
|
||||||
|
set +e
|
||||||
|
# rewrite build dir in egg links to /app so things are found at runtime
|
||||||
|
find .heroku/python/lib/python*/site-packages/ -name "*.pth" -print0 2> /dev/null | xargs -r -0 -n 1 sed -i -e "s#$(pwd)#/app#" &> /dev/null
|
||||||
|
set -e
|
||||||
|
|
||||||
|
set +e
|
||||||
|
# Support for PyPy
|
||||||
|
find .heroku/python/lib-python/*/site-packages/ -name "*.pth" -print0 2> /dev/null | xargs -r -0 -n 1 sed -i -e "s#$(pwd)#/app#" &> /dev/null
|
||||||
|
set -e
|
||||||
+6
-7
@@ -10,14 +10,13 @@
|
|||||||
# This script is invoked by [`bin/compile`](/).
|
# This script is invoked by [`bin/compile`](/).
|
||||||
|
|
||||||
# The location of the pre-compiled cryptography binary.
|
# The location of the pre-compiled cryptography binary.
|
||||||
VENDORED_GDAL="https://lang-python.s3.amazonaws.com/$STACK/libraries/vendor/gdal.tar.gz"
|
VENDORED_GDAL="${VENDOR_URL}/libraries/vendor/gdal.tar.gz"
|
||||||
|
|
||||||
PKG_CONFIG_PATH="/app/.heroku/vendor/lib/pkgconfig:$PKG_CONFIG_PATH"
|
PKG_CONFIG_PATH="/app/.heroku/vendor/lib/pkgconfig:$PKG_CONFIG_PATH"
|
||||||
|
|
||||||
# Syntax sugar.
|
# Syntax sugar.
|
||||||
source $BIN_DIR/utils
|
# shellcheck source=bin/utils
|
||||||
|
source "$BIN_DIR/utils"
|
||||||
bpwatch start gdal_install
|
|
||||||
|
|
||||||
# If GDAL exists within requirements, use vendored gdal.
|
# If GDAL exists within requirements, use vendored gdal.
|
||||||
if (pip-grep -s requirements.txt GDAL gdal pygdal &> /dev/null) then
|
if (pip-grep -s requirements.txt GDAL gdal pygdal &> /dev/null) then
|
||||||
@@ -26,10 +25,10 @@ if (pip-grep -s requirements.txt GDAL gdal pygdal &> /dev/null) then
|
|||||||
echo "-----> Noticed GDAL. Bootstrapping gdal."
|
echo "-----> Noticed GDAL. Bootstrapping gdal."
|
||||||
mkdir -p .heroku/vendor
|
mkdir -p .heroku/vendor
|
||||||
# Download and extract cryptography into target vendor directory.
|
# Download and extract cryptography into target vendor directory.
|
||||||
curl $VENDORED_GDAL -s | tar zxv -C .heroku/vendor &> /dev/null
|
curl "$VENDORED_GDAL" -s | tar zxv -C .heroku/vendor &> /dev/null
|
||||||
fi
|
fi
|
||||||
|
|
||||||
export GDAL=$(pwd)/vendor
|
GDAL=$(pwd)/vendor
|
||||||
|
export GDAL
|
||||||
fi
|
fi
|
||||||
|
|
||||||
bpwatch stop gdal_install
|
|
||||||
|
|||||||
+22
-12
@@ -10,16 +10,15 @@
|
|||||||
# This script is invoked by [`bin/compile`](/).
|
# This script is invoked by [`bin/compile`](/).
|
||||||
|
|
||||||
# The location of the pre-compiled cryptography binary.
|
# The location of the pre-compiled cryptography binary.
|
||||||
VENDORED_GDAL="https://lang-python.s3.amazonaws.com/$STACK/libraries/vendor/gdal.tar.gz"
|
VENDORED_GDAL="${VENDOR_URL}/libraries/vendor/gdal.tar.gz"
|
||||||
VENDORED_GEOS="https://lang-python.s3.amazonaws.com/$STACK/libraries/vendor/geos.tar.gz"
|
VENDORED_GEOS="${VENDOR_URL}/libraries/vendor/geos.tar.gz"
|
||||||
VENDORED_PROJ="https://lang-python.s3.amazonaws.com/$STACK/libraries/vendor/proj.tar.gz"
|
VENDORED_PROJ="${VENDOR_URL}/libraries/vendor/proj.tar.gz"
|
||||||
|
|
||||||
PKG_CONFIG_PATH="/app/.heroku/vendor/lib/pkgconfig:$PKG_CONFIG_PATH"
|
PKG_CONFIG_PATH="/app/.heroku/vendor/lib/pkgconfig:$PKG_CONFIG_PATH"
|
||||||
|
|
||||||
# Syntax sugar.
|
# Syntax sugar.
|
||||||
source $BIN_DIR/utils
|
# shellcheck source=bin/utils
|
||||||
|
source "$BIN_DIR/utils"
|
||||||
bpwatch start geo_libs_install
|
|
||||||
|
|
||||||
# If GDAL exists within requirements, use vendored gdal.
|
# If GDAL exists within requirements, use vendored gdal.
|
||||||
if [[ "$BUILD_WITH_GEO_LIBRARIES" ]]; then
|
if [[ "$BUILD_WITH_GEO_LIBRARIES" ]]; then
|
||||||
@@ -28,12 +27,23 @@ if [[ "$BUILD_WITH_GEO_LIBRARIES" ]]; then
|
|||||||
echo "-----> Bootstrapping gdal, geos, proj."
|
echo "-----> Bootstrapping gdal, geos, proj."
|
||||||
mkdir -p .heroku/vendor
|
mkdir -p .heroku/vendor
|
||||||
# Download and extract cryptography into target vendor directory.
|
# Download and extract cryptography into target vendor directory.
|
||||||
curl $VENDORED_GDAL -s | tar zxv -C .heroku/vendor &> /dev/null
|
curl "$VENDORED_GDAL" -s | tar zxv -C .heroku/vendor &> /dev/null
|
||||||
curl $VENDORED_GEOS -s | tar zxv -C .heroku/vendor &> /dev/null
|
curl "$VENDORED_GEOS" -s | tar zxv -C .heroku/vendor &> /dev/null
|
||||||
curl $VENDORED_PROJ -s | tar zxv -C .heroku/vendor &> /dev/null
|
curl "$VENDORED_PROJ" -s | tar zxv -C .heroku/vendor &> /dev/null
|
||||||
|
|
||||||
|
# Copy libjasper from build image to slug.
|
||||||
|
if [[ "$STACK" == "heroku-16" ]]; then
|
||||||
|
cp /usr/lib/x86_64-linux-gnu/libjasper.so* ".heroku/vendor/lib/."
|
||||||
|
fi
|
||||||
|
|
||||||
fi
|
fi
|
||||||
|
|
||||||
export GDAL=$(pwd)/vendor
|
GDAL=$(pwd)/vendor
|
||||||
|
export GDAL
|
||||||
|
# set path for post_compile hooks
|
||||||
|
export GDAL_LIBRARY_PATH="$BUILD_DIR/.heroku/vendor/lib/libgdal.so"
|
||||||
|
export GEOS_LIBRARY_PATH="$BUILD_DIR/.heroku/vendor/lib/libgeos_c.so"
|
||||||
|
# set path for runtime environmeht
|
||||||
|
set_env GDAL_LIBRARY_PATH "/app/.heroku/vendor/lib/libgdal.so"
|
||||||
|
set_env GEOS_LIBRARY_PATH "/app/.heroku/vendor/lib/libgeos_c.so"
|
||||||
fi
|
fi
|
||||||
|
|
||||||
bpwatch stop geo_libs_install
|
|
||||||
|
|||||||
@@ -3,5 +3,5 @@
|
|||||||
if [ -f bin/post_compile ]; then
|
if [ -f bin/post_compile ]; then
|
||||||
echo "-----> Running post-compile hook"
|
echo "-----> Running post-compile hook"
|
||||||
chmod +x bin/post_compile
|
chmod +x bin/post_compile
|
||||||
sub-env bin/post_compile
|
sub_env bin/post_compile
|
||||||
fi
|
fi
|
||||||
@@ -3,5 +3,5 @@
|
|||||||
if [ -f bin/pre_compile ]; then
|
if [ -f bin/pre_compile ]; then
|
||||||
echo "-----> Running pre-compile hook"
|
echo "-----> Running pre-compile hook"
|
||||||
chmod +x bin/pre_compile
|
chmod +x bin/pre_compile
|
||||||
sub-env bin/pre_compile
|
sub_env bin/pre_compile
|
||||||
fi
|
fi
|
||||||
+7
-4
@@ -1,6 +1,9 @@
|
|||||||
|
#!/usr/bin/env bash
|
||||||
|
|
||||||
# Install Mercurial if it appears to be required.
|
# Install Mercurial if it appears to be required.
|
||||||
if (grep -Fiq "hg+" requirements.txt) then
|
if [[ -f "requirements.txt" ]]; then
|
||||||
bpwatch start mercurial_install
|
if (grep -Fiq "hg+" requirements.txt) then
|
||||||
/app/.heroku/python/bin/pip install mercurial | cleanup | indent
|
/app/.heroku/python/bin/pip install mercurial | cleanup | indent
|
||||||
bpwatch stop mercurial_install
|
fi
|
||||||
fi
|
fi
|
||||||
|
|
||||||
|
|||||||
+15
-14
@@ -10,24 +10,25 @@
|
|||||||
# This script is invoked by [`bin/compile`](/).
|
# This script is invoked by [`bin/compile`](/).
|
||||||
|
|
||||||
# Syntax sugar.
|
# Syntax sugar.
|
||||||
source $BIN_DIR/utils
|
# shellcheck source=bin/utils
|
||||||
|
source "$BIN_DIR/utils"
|
||||||
bpwatch start nltk_download
|
|
||||||
|
|
||||||
# Check that nltk was installed by pip, otherwise obviously not needed
|
# Check that nltk was installed by pip, otherwise obviously not needed
|
||||||
python -m nltk.downloader -h >/dev/null 2>&1
|
if sp-grep -s nltk; then
|
||||||
if [ $? -eq 0 ]; then
|
puts-step "Downloading NLTK corpora…"
|
||||||
puts-step "Downloading NLTK corpora..."
|
|
||||||
nltk_packages_definition="$BUILD_DIR/nltk.txt"
|
nltk_packages_definition="$BUILD_DIR/nltk.txt"
|
||||||
|
|
||||||
if [ -f "$nltk_packages_definition" ]; then
|
if [ -f "$nltk_packages_definition" ]; then
|
||||||
nltk_packages=$(tr "\n" " " < "$nltk_packages_definition")
|
|
||||||
puts-step "Downloading NLTK packages: $nltk_packages"
|
readarray -t nltk_packages < "$nltk_packages_definition"
|
||||||
python -m nltk.downloader -d $BUILD_DIR/.heroku/python/nltk_data $nltk_packages | indent
|
puts-step "Downloading NLTK packages: ${nltk_packages[*]}"
|
||||||
set-env NLTK_DATA "/app/.heroku/python/nltk_data"
|
|
||||||
|
python -m nltk.downloader -d "$BUILD_DIR/.heroku/python/nltk_data" "${nltk_packages[@]}" | indent
|
||||||
|
set_env NLTK_DATA "/app/.heroku/python/nltk_data"
|
||||||
|
|
||||||
else
|
else
|
||||||
puts-warn "nltk.txt not found, not downloading any corpora"
|
puts-warn "'nltk.txt' not found, not downloading any corpora"
|
||||||
|
puts-warn "Learn more: https://devcenter.heroku.com/articles/python-nltk"
|
||||||
fi
|
fi
|
||||||
fi
|
fi
|
||||||
|
|
||||||
|
|
||||||
bpwatch stop nltk_download
|
|
||||||
|
|||||||
+59
-31
@@ -1,38 +1,66 @@
|
|||||||
# Install dependencies with Pip.
|
#!/usr/bin/env bash
|
||||||
puts-cmd "pip install -r requirements.txt"
|
|
||||||
|
|
||||||
set +e
|
# shellcheck source=bin/utils
|
||||||
# delete any existing egg links, to uninstall exisisting installations.
|
source "$BIN_DIR/utils"
|
||||||
find .heroku/python/lib/python*/site-packages/ -name "*.egg-link" -delete 2> /dev/null
|
|
||||||
find .heroku/python/lib/python*/site-packages/ -name "*.pth" -print0 2> /dev/null | xargs -r -0 -n 1 sed -i -e "s#/app/#/$(pwd)/#" &> /dev/null
|
|
||||||
set -e
|
|
||||||
|
|
||||||
set +e
|
if [ ! "$SKIP_PIP_INSTALL" ]; then
|
||||||
# Support for the above, for PyPy.
|
|
||||||
find .heroku/python/lib-python/*/site-packages/ -name "*.egg-link" -print0 2> /dev/null | xargs -r -0 -n 1 sed -i -e "s#/app/#$(pwd)/#" &> /dev/null
|
|
||||||
find .heroku/python/lib-python/*/site-packages/ -name "*.pth" -print0 2> /dev/null | xargs -r -0 -n 1 sed -i -e "s#/app/#/$(pwd)/#" &> /dev/null
|
|
||||||
set -e
|
|
||||||
|
|
||||||
[ ! "$FRESH_PYTHON" ] && bpwatch start pip_install
|
# Install dependencies with Pip.
|
||||||
[ "$FRESH_PYTHON" ] && bpwatch start pip_install_first
|
puts-step "Installing requirements with pip"
|
||||||
|
|
||||||
set +e
|
# Set Pip env vars
|
||||||
/app/.heroku/python/bin/pip install -r $BUILD_DIR/requirements.txt --exists-action=w --src=/app/.heroku/src --disable-pip-version-check --no-cache-dir 2>&1 | tee $WARNINGS_LOG | cleanup | indent
|
# This reads certain environment variables set on the Heroku app config
|
||||||
PIP_STATUS="${PIPESTATUS[0]}"
|
# and makes them accessible to the pip install process.
|
||||||
set -e
|
#
|
||||||
|
# PIP_EXTRA_INDEX_URL allows for an alternate pypi URL to be used.
|
||||||
|
if [[ -r "$ENV_DIR/PIP_EXTRA_INDEX_URL" ]]; then
|
||||||
|
PIP_EXTRA_INDEX_URL="$(cat "$ENV_DIR/PIP_EXTRA_INDEX_URL")"
|
||||||
|
export PIP_EXTRA_INDEX_URL
|
||||||
|
mcount "buildvar.PIP_EXTRA_INDEX_URL"
|
||||||
|
fi
|
||||||
|
|
||||||
show-warnings
|
set +e
|
||||||
|
|
||||||
if [[ ! $PIP_STATUS -eq 0 ]]; then
|
# Set SLUGIFY_USES_TEXT_UNIDECODE, required for Airflow versions >=1.10
|
||||||
exit 1
|
if [[ -r "$ENV_DIR/SLUGIFY_USES_TEXT_UNIDECODE" ]]; then
|
||||||
|
SLUGIFY_USES_TEXT_UNIDECODE="$(cat "$ENV_DIR/SLUGIFY_USES_TEXT_UNIDECODE")"
|
||||||
|
export SLUGIFY_USES_TEXT_UNIDECODE
|
||||||
|
mcount "buildvar.SLUGIFY_USES_TEXT_UNIDECODE"
|
||||||
|
fi
|
||||||
|
|
||||||
|
set +e
|
||||||
|
|
||||||
|
# Measure that we're using pip.
|
||||||
|
mcount "tool.pip"
|
||||||
|
|
||||||
|
# Count expected build failures.
|
||||||
|
if grep -q '==0.0.0' requirements.txt; then
|
||||||
|
mcount "failure.none-version"
|
||||||
|
fi
|
||||||
|
|
||||||
|
|
||||||
|
/app/.heroku/python/bin/pip install -r "$BUILD_DIR/requirements.txt" --exists-action=w --src=/app/.heroku/src --disable-pip-version-check --no-cache-dir 2>&1 | tee "$WARNINGS_LOG" | cleanup | indent
|
||||||
|
PIP_STATUS="${PIPESTATUS[0]}"
|
||||||
|
set -e
|
||||||
|
|
||||||
|
show-warnings
|
||||||
|
|
||||||
|
if [[ ! $PIP_STATUS -eq 0 ]]; then
|
||||||
|
mcount "failure.pip-install"
|
||||||
|
exit 1
|
||||||
|
fi
|
||||||
|
|
||||||
|
# Smart Requirements handling
|
||||||
|
cp requirements.txt .heroku/python/requirements-declared.txt
|
||||||
|
/app/.heroku/python/bin/pip freeze --disable-pip-version-check > .heroku/python/requirements-installed.txt
|
||||||
|
|
||||||
|
echo
|
||||||
|
|
||||||
|
# Install test dependencies, for CI.
|
||||||
|
if [ "$INSTALL_TEST" ]; then
|
||||||
|
if [[ -f "$1/requirements-test.txt" ]]; then
|
||||||
|
puts-step "Installing test dependencies…"
|
||||||
|
/app/.heroku/python/bin/pip install -r "$1/requirements-test.txt" --exists-action=w --src=./.heroku/src --disable-pip-version-check --no-cache-dir 2>&1 | cleanup | indent
|
||||||
|
fi
|
||||||
|
fi
|
||||||
fi
|
fi
|
||||||
|
|
||||||
|
|
||||||
# Smart Requirements handling
|
|
||||||
cp requirements.txt .heroku/python/requirements-declared.txt
|
|
||||||
/app/.heroku/python/bin/pip freeze --disable-pip-version-check > .heroku/python/requirements-installed.txt
|
|
||||||
|
|
||||||
[ ! "$FRESH_PYTHON" ] && bpwatch stop pip_install
|
|
||||||
[ "$FRESH_PYTHON" ] && bpwatch stop pip_install_first
|
|
||||||
|
|
||||||
echo
|
|
||||||
|
|||||||
+19
-9
@@ -1,18 +1,28 @@
|
|||||||
|
#!/usr/bin/env bash
|
||||||
|
|
||||||
set +e
|
set +e
|
||||||
# Install dependencies with Pip.
|
# Install dependencies with Pip.
|
||||||
bpwatch start pip_uninstall
|
# shellcheck source=bin/utils
|
||||||
if [[ -f .heroku/python/requirements-declared.txt ]]; then
|
source "$BIN_DIR/utils"
|
||||||
|
|
||||||
cp .heroku/python/requirements-declared.txt requirements-declared.txt
|
if [ ! "$SKIP_PIP_INSTALL" ]; then
|
||||||
|
|
||||||
pip-diff --stale requirements-declared.txt requirements.txt --exclude setuptools pip wheel > .heroku/python/requirements-stale.txt
|
if [[ -f .heroku/python/requirements-declared.txt ]]; then
|
||||||
|
|
||||||
rm -fr requirements-declared.txt
|
cp .heroku/python/requirements-declared.txt requirements-declared.txt
|
||||||
|
|
||||||
if [[ -s .heroku/python/requirements-stale.txt ]]; then
|
|
||||||
puts-step "Uninstalling stale dependencies"
|
if ! pip-diff --stale requirements-declared.txt requirements.txt --exclude setuptools pip wheel > .heroku/python/requirements-stale.txt; then
|
||||||
/app/.heroku/python/bin/pip uninstall -r .heroku/python/requirements-stale.txt -y --exists-action=w | cleanup | indent
|
mount "failure.bad-requirements"
|
||||||
|
fi
|
||||||
|
|
||||||
|
rm -fr requirements-declared.txt
|
||||||
|
|
||||||
|
if [[ -s .heroku/python/requirements-stale.txt ]]; then
|
||||||
|
puts-step "Uninstalling stale dependencies"
|
||||||
|
/app/.heroku/python/bin/pip uninstall -r .heroku/python/requirements-stale.txt -y --exists-action=w --disable-pip-version-check | cleanup | indent
|
||||||
|
fi
|
||||||
fi
|
fi
|
||||||
|
|
||||||
fi
|
fi
|
||||||
bpwatch stop pip_uninstall
|
|
||||||
set -e
|
set -e
|
||||||
|
|||||||
+80
-7
@@ -1,13 +1,86 @@
|
|||||||
# Generate requriements.txt with pipenv.
|
#!/usr/bin/env bash
|
||||||
|
|
||||||
if [[ -f Pipfile ]]; then
|
# export CLINT_FORCE_COLOR=1
|
||||||
if [[ ! -f requirements.txt ]]; then
|
# export PIPENV_FORCE_COLOR=1
|
||||||
puts-step "Generating 'requirements.txt' with pipenv"
|
# shellcheck source=bin/utils
|
||||||
|
source "$BIN_DIR/utils"
|
||||||
|
set -e
|
||||||
|
|
||||||
pip install git+https://github.com/kennethreitz/pipenv.git#egg=pipenv &> /dev/null
|
if [[ -f Pipfile.lock ]]; then
|
||||||
pipenv lock --requirements > requirements.txt 2> /dev/null
|
if [[ -f .heroku/python/Pipfile.lock.sha256 ]]; then
|
||||||
|
if [[ $(openssl dgst -sha256 Pipfile.lock) == $(cat .heroku/python/Pipfile.lock.sha256) ]]; then
|
||||||
|
# Measure that we're using Pipenv.
|
||||||
|
mcount "tool.pipenv"
|
||||||
|
|
||||||
pipstrip requirements.txt
|
# Don't skip installation of there are git deps.
|
||||||
|
if ! grep -q 'git' Pipfile.lock; then
|
||||||
|
echo "Skipping installation, as Pipfile.lock hasn't changed since last deploy." | indent
|
||||||
|
|
||||||
|
mcount "tool.pipenv"
|
||||||
|
export SKIP_PIPENV_INSTALL=1
|
||||||
|
export SKIP_PIP_INSTALL=1
|
||||||
|
fi
|
||||||
|
fi
|
||||||
fi
|
fi
|
||||||
fi
|
fi
|
||||||
|
|
||||||
|
|
||||||
|
if [ ! "$SKIP_PIPENV_INSTALL" ]; then
|
||||||
|
# Pipenv support (Generate requriements.txt with pipenv).
|
||||||
|
if [[ -f Pipfile ]]; then
|
||||||
|
# Measure that we're using Pipenv.
|
||||||
|
mcount "tool.pipenv"
|
||||||
|
|
||||||
|
# Skip pip install, later.
|
||||||
|
export SKIP_PIP_INSTALL=1
|
||||||
|
|
||||||
|
# Set Pip env vars
|
||||||
|
# This reads certain environment variables set on the Heroku app config
|
||||||
|
# and makes them accessible to the pip install process.
|
||||||
|
#
|
||||||
|
# PIP_EXTRA_INDEX_URL allows for an alternate pypi URL to be used.
|
||||||
|
if [[ -r "$ENV_DIR/PIP_EXTRA_INDEX_URL" ]]; then
|
||||||
|
PIP_EXTRA_INDEX_URL="$(cat "$ENV_DIR/PIP_EXTRA_INDEX_URL")"
|
||||||
|
export PIP_EXTRA_INDEX_URL
|
||||||
|
mcount "buildvar.PIP_EXTRA_INDEX_URL"
|
||||||
|
fi
|
||||||
|
|
||||||
|
# Set SLUGIFY_USES_TEXT_UNIDECODE, required for Airflow versions >=1.10
|
||||||
|
if [[ -r "$ENV_DIR/SLUGIFY_USES_TEXT_UNIDECODE" ]]; then
|
||||||
|
SLUGIFY_USES_TEXT_UNIDECODE="$(cat "$ENV_DIR/SLUGIFY_USES_TEXT_UNIDECODE")"
|
||||||
|
export SLUGIFY_USES_TEXT_UNIDECODE
|
||||||
|
mcount "buildvar.SLUGIFY_USES_TEXT_UNIDECODE"
|
||||||
|
fi
|
||||||
|
|
||||||
|
export PIPENV_VERSION="2018.5.18"
|
||||||
|
|
||||||
|
# Install pipenv.
|
||||||
|
# Due to weird old pip behavior and pipenv behavior, pipenv upgrades pip
|
||||||
|
# to latest if only --upgrade is specified. Specify upgrade strategy to
|
||||||
|
# avoid this eager behavior.
|
||||||
|
/app/.heroku/python/bin/pip install pipenv==$PIPENV_VERSION --upgrade --upgrade-strategy only-if-needed &> /dev/null
|
||||||
|
|
||||||
|
# Install the dependencies.
|
||||||
|
if [[ ! -f Pipfile.lock ]]; then
|
||||||
|
puts-step "Installing dependencies with Pipenv $PIPENV_VERSION…"
|
||||||
|
/app/.heroku/python/bin/pipenv install --system --skip-lock 2>&1 | indent
|
||||||
|
else
|
||||||
|
pipenv-to-pip Pipfile.lock > requirements.txt
|
||||||
|
"$BIN_DIR/steps/pip-uninstall"
|
||||||
|
cp requirements.txt .heroku/python/requirements-declared.txt
|
||||||
|
openssl dgst -sha256 Pipfile.lock > .heroku/python/Pipfile.lock.sha256
|
||||||
|
|
||||||
|
puts-step "Installing dependencies with Pipenv $PIPENV_VERSION…"
|
||||||
|
/app/.heroku/python/bin/pipenv install --system --deploy 2>&1 | indent
|
||||||
|
fi
|
||||||
|
|
||||||
|
# Install the test dependencies, for CI.
|
||||||
|
if [ "$INSTALL_TEST" ]; then
|
||||||
|
puts-step "Installing test dependencies…"
|
||||||
|
/app/.heroku/python/bin/pipenv install --dev --system --deploy 2>&1 | cleanup | indent
|
||||||
|
fi
|
||||||
|
fi
|
||||||
|
else
|
||||||
|
export SKIP_PIP_INSTALL=1
|
||||||
|
pipenv-to-pip Pipfile.lock > requirements.txt
|
||||||
|
fi
|
||||||
|
|||||||
@@ -1,21 +1,35 @@
|
|||||||
|
#!/usr/bin/env bash
|
||||||
|
|
||||||
# Detect Python-version with Pipenv.
|
# Detect Python-version with Pipenv.
|
||||||
|
|
||||||
if [[ -f $BUILD_DIR/Pipfile.lock ]]; then
|
if [[ -f $BUILD_DIR/Pipfile ]]; then
|
||||||
|
|
||||||
if [[ ! -f $BUILD_DIR/runtime.txt ]]; then
|
if [[ ! -f $BUILD_DIR/runtime.txt ]]; then
|
||||||
if [[ ! -f Pipfile.lock ]]; then
|
if [[ ! -f $BUILD_DIR/Pipfile.lock ]]; then
|
||||||
pipenv lock 2> /dev/null
|
puts-warn "No 'Pipfile.lock' found! We recommend you commit this into your repository."
|
||||||
fi
|
fi
|
||||||
|
if [[ -f $BUILD_DIR/Pipfile.lock ]]; then
|
||||||
|
set +e
|
||||||
|
PYTHON=$(jq -r '._meta.requires.python_full_version' "$BUILD_DIR/Pipfile.lock")
|
||||||
|
if [[ "$PYTHON" != "null" ]]; then
|
||||||
|
echo "python-$PYTHON" > "$BUILD_DIR/runtime.txt"
|
||||||
|
fi
|
||||||
|
set -e
|
||||||
|
|
||||||
|
if [[ "$PYTHON" == "null" ]]; then
|
||||||
|
PYTHON=$(jq -r '._meta.requires.python_version' "$BUILD_DIR/Pipfile.lock")
|
||||||
|
if [ "$PYTHON" = 2.7 ]; then
|
||||||
|
echo "$LATEST_2" > "$BUILD_DIR/runtime.txt"
|
||||||
|
fi
|
||||||
|
if [ "$PYTHON" = 3.6 ]; then
|
||||||
|
echo "$LATEST_36" > "$BUILD_DIR/runtime.txt"
|
||||||
|
fi
|
||||||
|
if [ "$PYTHON" = 3.7 ]; then
|
||||||
|
echo "$LATEST_37" > "$BUILD_DIR/runtime.txt"
|
||||||
|
fi
|
||||||
|
fi
|
||||||
|
|
||||||
set +e
|
|
||||||
PYTHON=$(cat $BUILD_DIR/Pipfile.lock | jq '._meta.requires.python_version' -r)
|
|
||||||
set -e
|
|
||||||
|
|
||||||
if [ "$PYTHON" = 2.7 ]; then
|
|
||||||
echo "python-2.7.13" > $BUILD_DIR/runtime.txt
|
|
||||||
fi
|
|
||||||
if [ "$PYTHON" = 3.6 ]; then
|
|
||||||
echo "python-3.6.0" > $BUILD_DIR/runtime.txt
|
|
||||||
fi
|
fi
|
||||||
fi
|
fi
|
||||||
fi
|
fi
|
||||||
|
|||||||
+11
-9
@@ -9,14 +9,17 @@
|
|||||||
#
|
#
|
||||||
# This script is invoked by [`bin/compile`](/).
|
# This script is invoked by [`bin/compile`](/).
|
||||||
|
|
||||||
|
if [[ "$STACK" != "cedar-14" ]]; then
|
||||||
|
# libmemcached is pre-installed in the stack image so there is no need to vendor it.
|
||||||
|
return 0
|
||||||
|
fi
|
||||||
|
|
||||||
# The location of the pre-compiled libmemcached binary.
|
# The location of the pre-compiled libmemcached binary.
|
||||||
VENDORED_MEMCACHED="https://lang-python.s3.amazonaws.com/$STACK/libraries/vendor/libmemcache.tar.gz"
|
VENDORED_MEMCACHED="${VENDOR_URL}/libraries/vendor/libmemcache.tar.gz"
|
||||||
|
|
||||||
# Syntax sugar.
|
# Syntax sugar.
|
||||||
source $BIN_DIR/utils
|
# shellcheck source=bin/utils
|
||||||
|
source "$BIN_DIR/utils"
|
||||||
|
|
||||||
bpwatch start pylibmc_install
|
|
||||||
|
|
||||||
# If pylibmc exists within requirements, use vendored libmemcached.
|
# If pylibmc exists within requirements, use vendored libmemcached.
|
||||||
if (pip-grep -s requirements.txt pylibmc &> /dev/null) then
|
if (pip-grep -s requirements.txt pylibmc &> /dev/null) then
|
||||||
@@ -25,10 +28,9 @@ if (pip-grep -s requirements.txt pylibmc &> /dev/null) then
|
|||||||
echo "-----> Noticed pylibmc. Bootstrapping libmemcached."
|
echo "-----> Noticed pylibmc. Bootstrapping libmemcached."
|
||||||
mkdir -p .heroku/vendor
|
mkdir -p .heroku/vendor
|
||||||
# Download and extract libmemcached into target vendor directory.
|
# Download and extract libmemcached into target vendor directory.
|
||||||
curl $VENDORED_MEMCACHED -s | tar zxv -C .heroku/vendor &> /dev/null
|
curl "$VENDORED_MEMCACHED" -s | tar zxv -C .heroku/vendor &> /dev/null
|
||||||
fi
|
fi
|
||||||
|
|
||||||
export LIBMEMCACHED=$(pwd)/vendor
|
LIBMEMCACHED=$(pwd)/vendor
|
||||||
|
export LIBMEMCACHED
|
||||||
fi
|
fi
|
||||||
|
|
||||||
bpwatch stop pylibmc_install
|
|
||||||
|
|||||||
+78
-40
@@ -1,77 +1,115 @@
|
|||||||
|
#!/usr/bin/env bash
|
||||||
|
|
||||||
set +e
|
set +e
|
||||||
|
runtime-fixer runtime.txt
|
||||||
PYTHON_VERSION=$(cat runtime.txt)
|
PYTHON_VERSION=$(cat runtime.txt)
|
||||||
|
|
||||||
# Install Python.
|
# The location of the pre-compiled python binary.
|
||||||
|
VENDORED_PYTHON="${VENDOR_URL}/runtimes/$PYTHON_VERSION.tar.gz"
|
||||||
|
|
||||||
|
SECURITY_UPDATE="Python has released a security update! Please consider upgrading to"
|
||||||
|
|
||||||
|
# check if runtime exists
|
||||||
|
if curl --output /dev/null --silent --head --fail "$VENDORED_PYTHON"; then
|
||||||
|
if [[ "$PYTHON_VERSION" == $PY37* ]]; then
|
||||||
|
# do things to alert the user of security release available
|
||||||
|
if [ "$PYTHON_VERSION" != "$LATEST_37" ]; then
|
||||||
|
puts-warn "$SECURITY_UPDATE" "$LATEST_37"
|
||||||
|
echo " Learn More: https://devcenter.heroku.com/articles/python-runtimes"
|
||||||
|
fi
|
||||||
|
fi
|
||||||
|
if [[ "$PYTHON_VERSION" == $PY36* ]]; then
|
||||||
|
# security update note
|
||||||
|
if [ "$PYTHON_VERSION" != "$LATEST_36" ]; then
|
||||||
|
puts-warn "$SECURITY_UPDATE" "$LATEST_36"
|
||||||
|
echo " Learn More: https://devcenter.heroku.com/articles/python-runtimes"
|
||||||
|
fi
|
||||||
|
fi
|
||||||
|
if [[ "$PYTHON_VERSION" == $PY35* ]]; then
|
||||||
|
# security update note
|
||||||
|
if [ "$PYTHON_VERSION" != "$LATEST_35" ]; then
|
||||||
|
puts-warn "$SECURITY_UPDATE" "$LATEST_35"
|
||||||
|
echo " Learn More: https://devcenter.heroku.com/articles/python-runtimes"
|
||||||
|
fi
|
||||||
|
fi
|
||||||
|
if [[ "$PYTHON_VERSION" == $PY34* ]]; then
|
||||||
|
# security update note
|
||||||
|
if [ "$PYTHON_VERSION" != "$LATEST_34" ]; then
|
||||||
|
puts-warn "$SECURITY_UPDATE" "$LATEST_34"
|
||||||
|
echo " Learn More: https://devcenter.heroku.com/articles/python-runtimes"
|
||||||
|
fi
|
||||||
|
fi
|
||||||
|
if [[ "$PYTHON_VERSION" == $PY27* ]]; then
|
||||||
|
# security update note
|
||||||
|
if [ "$PYTHON_VERSION" != "$LATEST_27" ]; then
|
||||||
|
puts-warn "$SECURITY_UPDATE" "$LATEST_27"
|
||||||
|
echo " Learn More: https://devcenter.heroku.com/articles/python-runtimes"
|
||||||
|
fi
|
||||||
|
fi
|
||||||
|
else
|
||||||
|
puts-warn "Requested runtime ($PYTHON_VERSION) is not available for this stack ($STACK)."
|
||||||
|
puts-warn "Aborting. More info: https://devcenter.heroku.com/articles/python-support"
|
||||||
|
exit 1
|
||||||
|
fi
|
||||||
|
|
||||||
|
if [[ "$STACK" != "$CACHED_PYTHON_STACK" ]]; then
|
||||||
|
puts-step "Stack has changed from $CACHED_PYTHON_STACK to $STACK, clearing cache"
|
||||||
|
rm -fr .heroku/python-stack .heroku/python-version .heroku/python .heroku/vendor .heroku/python .heroku/python-sqlite3-version
|
||||||
|
fi
|
||||||
|
|
||||||
|
# need to clear the cache for first time installing SQLite3,
|
||||||
|
# since the version is changing and could lead to runtime errors
|
||||||
|
# with compiled extensions.
|
||||||
|
if [ -d .heroku/python ] && [ ! -f .heroku/python-sqlite3-version ] && python_sqlite3_check "$PYTHON_VERSION"; then
|
||||||
|
puts-step "Need to update SQLite3, clearing cache"
|
||||||
|
rm -fr .heroku/python-stack .heroku/python-version .heroku/python .heroku/vendor
|
||||||
|
fi
|
||||||
|
|
||||||
if [ -f .heroku/python-version ]; then
|
if [ -f .heroku/python-version ]; then
|
||||||
if [ ! $(cat .heroku/python-version) = $PYTHON_VERSION ]; then
|
if [ ! "$(cat .heroku/python-version)" = "$PYTHON_VERSION" ]; then
|
||||||
bpwatch start uninstall_python
|
|
||||||
puts-step "Found $(cat .heroku/python-version), removing"
|
puts-step "Found $(cat .heroku/python-version), removing"
|
||||||
rm -fr .heroku/python
|
rm -fr .heroku/python
|
||||||
bpwatch stop uninstall_python
|
|
||||||
else
|
else
|
||||||
SKIP_INSTALL=1
|
SKIP_INSTALL=1
|
||||||
fi
|
fi
|
||||||
fi
|
fi
|
||||||
|
|
||||||
if [ ! $STACK = $CACHED_PYTHON_STACK ]; then
|
|
||||||
bpwatch start uninstall_python
|
|
||||||
rm -fr .heroku/python .heroku/python-stack .heroku/vendor
|
|
||||||
unset SKIP_INSTALL
|
|
||||||
bpwatch stop uninstall_python
|
|
||||||
fi
|
|
||||||
|
|
||||||
|
|
||||||
if [ ! "$SKIP_INSTALL" ]; then
|
if [ ! "$SKIP_INSTALL" ]; then
|
||||||
bpwatch start install_python
|
|
||||||
puts-step "Installing $PYTHON_VERSION"
|
puts-step "Installing $PYTHON_VERSION"
|
||||||
|
|
||||||
# Prepare destination directory.
|
# Prepare destination directory.
|
||||||
mkdir -p .heroku/python
|
mkdir -p .heroku/python
|
||||||
|
|
||||||
curl https://lang-python.s3.amazonaws.com/$STACK/runtimes/$PYTHON_VERSION.tar.gz -s | tar zxv -C .heroku/python &> /dev/null
|
mcount "version.python.$PYTHON_VERSION"
|
||||||
if [[ $? != 0 ]] ; then
|
|
||||||
|
if ! curl "${VENDORED_PYTHON}" -s | tar zxv -C .heroku/python &> /dev/null; then
|
||||||
puts-warn "Requested runtime ($PYTHON_VERSION) is not available for this stack ($STACK)."
|
puts-warn "Requested runtime ($PYTHON_VERSION) is not available for this stack ($STACK)."
|
||||||
puts-warn "Aborting. More info: https://devcenter.heroku.com/articles/python-support"
|
puts-warn "Aborting. More info: https://devcenter.heroku.com/articles/python-support"
|
||||||
exit 1
|
exit 1
|
||||||
fi
|
fi
|
||||||
|
|
||||||
bpwatch stop install_python
|
|
||||||
|
|
||||||
# Record for future reference.
|
# Record for future reference.
|
||||||
echo $PYTHON_VERSION > .heroku/python-version
|
echo "$PYTHON_VERSION" > .heroku/python-version
|
||||||
echo $STACK > .heroku/python-stack
|
echo "$STACK" > .heroku/python-stack
|
||||||
FRESH_PYTHON=true
|
FRESH_PYTHON=true
|
||||||
|
|
||||||
hash -r
|
hash -r
|
||||||
fi
|
fi
|
||||||
|
|
||||||
|
|
||||||
# If Pip isn't up to date:
|
# If Pip isn't up to date:
|
||||||
if [ "$FRESH_PYTHON" ] || [[ ! $(pip --version) == *$PIP_VERSION* ]]; then
|
if [ "$FRESH_PYTHON" ] || [[ ! $(pip --version) == *$PIP_UPDATE* ]]; then
|
||||||
WORKING_DIR=$(pwd)
|
|
||||||
|
|
||||||
bpwatch start prepare_environment
|
puts-step "Installing pip"
|
||||||
|
|
||||||
TMPTARDIR=$(mktemp -d)
|
# Remove old installations.
|
||||||
trap "rm -rf $TMPTARDIR" RETURN
|
rm -fr /app/.heroku/python/lib/python*/site-packages/pip-*
|
||||||
|
rm -fr /app/.heroku/python/lib/python*/site-packages/setuptools-*
|
||||||
|
|
||||||
bpwatch start install_setuptools
|
/app/.heroku/python/bin/python "$ROOT_DIR/vendor/get-pip.py" pip=="$PIP_UPDATE" &> /dev/null
|
||||||
# Prepare it for the real world
|
/app/.heroku/python/bin/pip install "$ROOT_DIR/vendor/setuptools-39.0.1-py2.py3-none-any.whl" &> /dev/null
|
||||||
# puts-step "Installing Setuptools ($SETUPTOOLS_VERSION)"
|
|
||||||
tar zxf $ROOT_DIR/vendor/setuptools-$SETUPTOOLS_VERSION.tar.gz -C $TMPTARDIR
|
|
||||||
cd $TMPTARDIR/setuptools-$SETUPTOOLS_VERSION/
|
|
||||||
python setup.py install &> /dev/null
|
|
||||||
cd $WORKING_DIR
|
|
||||||
bpwatch stop install_setuptoools
|
|
||||||
|
|
||||||
bpwatch start install_pip
|
|
||||||
# puts-step "Installing Pip ($PIP_VERSION)"
|
|
||||||
tar zxf $ROOT_DIR/vendor/pip-$PIP_VERSION.tar.gz -C $TMPTARDIR
|
|
||||||
cd $TMPTARDIR/pip-$PIP_VERSION/
|
|
||||||
python setup.py install &> /dev/null
|
|
||||||
cd $WORKING_DIR
|
|
||||||
|
|
||||||
bpwatch stop install_pip
|
|
||||||
bpwatch stop prepare_environment
|
|
||||||
fi
|
fi
|
||||||
|
|
||||||
set -e
|
set -e
|
||||||
|
|||||||
@@ -1,11 +0,0 @@
|
|||||||
#!/usr/bin/env bash
|
|
||||||
|
|
||||||
# Syntax sugar.
|
|
||||||
source $BIN_DIR/utils
|
|
||||||
|
|
||||||
if (pip-grep -s requirements.txt setuptools distribute &> /dev/null) then
|
|
||||||
|
|
||||||
puts-warn 'The package setuptools/distribute is listed in requirements.txt.'
|
|
||||||
puts-warn 'Please remove to ensure expected behavior. '
|
|
||||||
|
|
||||||
fi
|
|
||||||
@@ -0,0 +1,87 @@
|
|||||||
|
#!/usr/bin/env bash
|
||||||
|
|
||||||
|
# shellcheck source=bin/utils
|
||||||
|
source "$BIN_DIR/utils"
|
||||||
|
|
||||||
|
sqlite3_version() {
|
||||||
|
SQLITE3_VERSION=${SQLITE3_VERSION:-$(dpkg -s libsqlite3-0 | grep Version | sed 's/Version: //')}
|
||||||
|
|
||||||
|
export SQLITE3_VERSION
|
||||||
|
}
|
||||||
|
|
||||||
|
sqlite3_install() {
|
||||||
|
HEROKU_PYTHON_DIR="$1"
|
||||||
|
SQLITE3_VERSION="$2"
|
||||||
|
HEADERS_ONLY="$3"
|
||||||
|
|
||||||
|
mkdir -p "$HEROKU_PYTHON_DIR"
|
||||||
|
|
||||||
|
APT_CACHE_DIR="$HEROKU_PYTHON_DIR/apt/cache"
|
||||||
|
APT_STATE_DIR="$HEROKU_PYTHON_DIR/apt/state"
|
||||||
|
|
||||||
|
mkdir -p "$APT_CACHE_DIR/archives/partial"
|
||||||
|
mkdir -p "$APT_STATE_DIR/lists/partial"
|
||||||
|
|
||||||
|
APT_OPTIONS="-o debug::nolocking=true"
|
||||||
|
APT_OPTIONS="$APT_OPTIONS -o dir::cache=$APT_CACHE_DIR"
|
||||||
|
APT_OPTIONS="$APT_OPTIONS -o dir::state=$APT_STATE_DIR"
|
||||||
|
APT_OPTIONS="$APT_OPTIONS -o dir::etc::sourcelist=/etc/apt/sources.list"
|
||||||
|
|
||||||
|
apt-get $APT_OPTIONS update > /dev/null 2>&1
|
||||||
|
if [ -z "$HEADERS_ONLY" ]; then
|
||||||
|
apt-get $APT_OPTIONS -y -d --reinstall install libsqlite3-dev="$SQLITE3_VERSION" sqlite3="$SQLITE3_VERSION" > /dev/null 2>&1
|
||||||
|
else
|
||||||
|
apt-get $APT_OPTIONS -y -d --reinstall install libsqlite3-dev="$SQLITE3_VERSION"
|
||||||
|
fi
|
||||||
|
|
||||||
|
find "$APT_CACHE_DIR/archives/" -name "*.deb" -exec dpkg -x {} "$HEROKU_PYTHON_DIR/sqlite3/" \;
|
||||||
|
|
||||||
|
mkdir -p "$HEROKU_PYTHON_DIR/include"
|
||||||
|
mkdir -p "$HEROKU_PYTHON_DIR/lib"
|
||||||
|
|
||||||
|
# remove old sqlite3 libraries/binaries
|
||||||
|
find "$HEROKU_PYTHON_DIR/include/" -name "sqlite3*.h" -exec rm -f {} \;
|
||||||
|
find "$HEROKU_PYTHON_DIR/lib/" -name "libsqlite3.*" -exec rm -f {} \;
|
||||||
|
rm -f "$HEROKU_PYTHON_DIR/lib/pkgconfig/sqlite3.pc"
|
||||||
|
rm -f "$HEROKU_PYTHON_DIR/bin/sqlite3"
|
||||||
|
|
||||||
|
# copy over sqlite3 headers & bins and setup linking against the stack image library
|
||||||
|
mv "$HEROKU_PYTHON_DIR/sqlite3/usr/include/"* "$HEROKU_PYTHON_DIR/include/"
|
||||||
|
mv "$HEROKU_PYTHON_DIR/sqlite3/usr/lib/x86_64-linux-gnu"/libsqlite3.*a "$HEROKU_PYTHON_DIR/lib/"
|
||||||
|
mkdir -p "$HEROKU_PYTHON_DIR/lib/pkgconfig"
|
||||||
|
# set the right prefix/lib directories
|
||||||
|
sed -e 's/prefix=\/usr/prefix=\/app\/.heroku\/python/' -e 's/\/x86_64-linux-gnu//' "$HEROKU_PYTHON_DIR/sqlite3/usr/lib/x86_64-linux-gnu/pkgconfig/sqlite3.pc" > "$HEROKU_PYTHON_DIR/lib/pkgconfig/sqlite3.pc"
|
||||||
|
# need to point the libsqlite3.so to the stack image library for /usr/bin/ld -lsqlite3
|
||||||
|
SQLITE3_LIBFILE="/usr/lib/x86_64-linux-gnu/$(readlink -n "$HEROKU_PYTHON_DIR/sqlite3/usr/lib/x86_64-linux-gnu/libsqlite3.so")"
|
||||||
|
ln -s "$SQLITE3_LIBFILE" "$HEROKU_PYTHON_DIR/lib/libsqlite3.so"
|
||||||
|
if [ -z "$HEADERS_ONLY" ]; then
|
||||||
|
mv "$HEROKU_PYTHON_DIR/sqlite3/usr/bin"/* "$HEROKU_PYTHON_DIR/bin/"
|
||||||
|
fi
|
||||||
|
|
||||||
|
# cleanup
|
||||||
|
rm -rf "$HEROKU_PYTHON_DIR/sqlite3/"
|
||||||
|
rm -rf "$HEROKU_PYTHON_DIR/apt/"
|
||||||
|
}
|
||||||
|
|
||||||
|
buildpack_sqlite3_install() {
|
||||||
|
sqlite3_version
|
||||||
|
HEROKU_PYTHON_DIR="$BUILD_DIR/.heroku/python"
|
||||||
|
|
||||||
|
SQLITE3_VERSION_FILE="$BUILD_DIR/.heroku/python-sqlite3-version"
|
||||||
|
if [ -f "$SQLITE3_VERSION_FILE" ]; then
|
||||||
|
INSTALLED_SQLITE3_VERSION=$(cat "$SQLITE3_VERSION_FILE")
|
||||||
|
fi
|
||||||
|
|
||||||
|
# python version check
|
||||||
|
if python_sqlite3_check "$PYTHON_VERSION"; then
|
||||||
|
# only install if the sqlite3 version has changed
|
||||||
|
if [ "$INSTALLED_SQLITE3_VERSION" != "$SQLITE3_VERSION" ]; then
|
||||||
|
puts-step "Installing SQLite3"
|
||||||
|
sqlite3_install "$BUILD_DIR/.heroku/python" "$SQLITE3_VERSION"
|
||||||
|
|
||||||
|
# save version installed
|
||||||
|
mkdir -p "$CACHE_DIR/.heroku/"
|
||||||
|
echo "$SQLITE3_VERSION" > "$CACHE_DIR/.heroku/python-sqlite3-version"
|
||||||
|
fi
|
||||||
|
fi
|
||||||
|
}
|
||||||
+8
-6
@@ -1,11 +1,13 @@
|
|||||||
#!/usr/bin/env bash
|
#!/usr/bin/env bash
|
||||||
|
|
||||||
# Syntax sugar.
|
# Syntax sugar.
|
||||||
BIN_DIR=$(cd $(dirname $0); pwd) # absolute path
|
BIN_DIR=$(cd "$(dirname "$0")" || return; pwd) # absolute path
|
||||||
source $BIN_DIR/utils
|
|
||||||
|
|
||||||
DISABLE_COLLECTSTATIC=1 "$(dirname ${0:-})/compile" "$1" "$2" "$3"
|
# shellcheck source=bin/utils
|
||||||
|
source "$BIN_DIR/utils"
|
||||||
|
|
||||||
if [[ -f "$1/requirements-test.txt" ]]; then
|
# Locale support for Pipenv.
|
||||||
/app/.heroku/python/bin/pip install -r "$1/requirements-test.txt" --exists-action=w --src=./.heroku/src --disable-pip-version-check --no-cache-dir 2>&1 | cleanup | indent
|
export LC_ALL=C.UTF-8
|
||||||
fi
|
export LANG=C.UTF-8
|
||||||
|
|
||||||
|
DISABLE_COLLECTSTATIC=1 INSTALL_TEST=1 "$(dirname "${0:-}")/compile" "$1" "$2" "$3"
|
||||||
@@ -1,6 +1,15 @@
|
|||||||
|
#!/usr/bin/env bash
|
||||||
shopt -s extglob
|
shopt -s extglob
|
||||||
|
shopt -s nullglob
|
||||||
|
|
||||||
if [ $(uname) == Darwin ]; then
|
# The standard library.
|
||||||
|
if [[ ! -f /tmp/stdlib.sh ]]; then
|
||||||
|
curl --retry 3 -s https://lang-common.s3.amazonaws.com/buildpack-stdlib/v8/stdlib.sh > /tmp/stdlib.sh
|
||||||
|
fi
|
||||||
|
# shellcheck source=/dev/null
|
||||||
|
source /tmp/stdlib.sh
|
||||||
|
|
||||||
|
if [ "$(uname)" == Darwin ]; then
|
||||||
sed() { command sed -l "$@"; }
|
sed() { command sed -l "$@"; }
|
||||||
else
|
else
|
||||||
sed() { command sed -u "$@"; }
|
sed() { command sed -u "$@"; }
|
||||||
@@ -11,46 +20,20 @@ indent() {
|
|||||||
sed "s/^/ /"
|
sed "s/^/ /"
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
# Clean up pip output
|
# Clean up pip output
|
||||||
cleanup() {
|
cleanup() {
|
||||||
sed -e 's/\.\.\.\+/.../g' | sed -e '/already satisfied/Id' | sed -e '/No files were found to uninstall/Id' | sed -e '/Overwriting/Id' | sed -e '/python executable/Id' | sed -e '/no previously-included files/Id'
|
sed -e 's/\.\.\.\+/.../g' | sed -e '/already satisfied/Id' | sed -e '/No files were found to uninstall/Id' | sed -e '/Overwriting/Id' | sed -e '/python executable/Id' | sed -e '/no previously-included files/Id'
|
||||||
}
|
}
|
||||||
|
|
||||||
# Buildpack Indented line.
|
|
||||||
puts-line() {
|
|
||||||
echo " $@"
|
|
||||||
}
|
|
||||||
|
|
||||||
# Buildpack Steps.
|
# Buildpack Steps.
|
||||||
puts-step() {
|
puts-step() {
|
||||||
echo "-----> $@"
|
echo "-----> $*"
|
||||||
}
|
}
|
||||||
|
|
||||||
# Buildpack Warnings.
|
# Buildpack Warnings.
|
||||||
puts-warn() {
|
puts-warn() {
|
||||||
echo " ! $@"
|
echo " ! $*"
|
||||||
}
|
|
||||||
|
|
||||||
# Buildpack Commands.
|
|
||||||
puts-cmd() {
|
|
||||||
echo " $ $@"
|
|
||||||
}
|
|
||||||
|
|
||||||
# Usage: $ set-env key value
|
|
||||||
set-env() {
|
|
||||||
echo "export $1=$2" >> $PROFILE_PATH
|
|
||||||
echo "export $1=$2" >> $EXPORT_PATH
|
|
||||||
}
|
|
||||||
|
|
||||||
# Usage: $ set-default-env key value
|
|
||||||
set-default-env() {
|
|
||||||
echo "export $1=\${$1:-$2}" >> $PROFILE_PATH
|
|
||||||
echo "export $1=\${$1:-$2}" >> $EXPORT_PATH
|
|
||||||
}
|
|
||||||
|
|
||||||
# Usage: $ un-set-env key
|
|
||||||
un-set-env() {
|
|
||||||
echo "unset $1" >> $PROFILE_PATH
|
|
||||||
}
|
}
|
||||||
|
|
||||||
# Does some serious copying.
|
# Does some serious copying.
|
||||||
@@ -69,42 +52,46 @@ deep-cp() {
|
|||||||
)
|
)
|
||||||
}
|
}
|
||||||
|
|
||||||
# Does some serious moving.
|
|
||||||
deep-mv() {
|
# Measure the size of the Python installation.
|
||||||
deep-cp "$1" "$2"
|
measure-size() {
|
||||||
deep-rm "$1"
|
echo "$(du -s .heroku/python 2>/dev/null || echo 0) | awk '{print $1}')"
|
||||||
}
|
}
|
||||||
|
|
||||||
# Does some serious deleting.
|
# Python version operator >
|
||||||
deep-rm() {
|
version_gt() {
|
||||||
# subshell to avoid surprising caller with shopts.
|
test "$(printf '%s\n' "$@" | sort -V | head -n 1)" != "$1";
|
||||||
(
|
|
||||||
shopt -s dotglob
|
|
||||||
rm -rf "$1"/!(.curlrc|.netrc|tmp|.|..)
|
|
||||||
)
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
# Python verison operator >=
|
||||||
|
version_gte() {
|
||||||
|
if [ "$1" == "$2" ]; then
|
||||||
|
return 0
|
||||||
|
fi
|
||||||
|
|
||||||
sub-env() {
|
version_gt "$1" "$2"
|
||||||
|
|
||||||
WHITELIST=${2:-''}
|
|
||||||
BLACKLIST=${3:-'^(GIT_DIR|PYTHONHOME|LD_LIBRARY_PATH|LIBRARY_PATH|PATH)$'}
|
|
||||||
|
|
||||||
# Python-specific variables.
|
|
||||||
export PYHONHOME=$BUILD_DIR/.heroku/python
|
|
||||||
export PYTHONPATH=$BUILD_DIR/
|
|
||||||
|
|
||||||
(
|
|
||||||
if [ -d "$ENV_DIR" ]; then
|
|
||||||
for e in $(ls $ENV_DIR); do
|
|
||||||
echo "$e" | grep -E "$WHITELIST" | grep -qvE "$BLACKLIST" &&
|
|
||||||
export "$e=$(cat $ENV_DIR/$e)"
|
|
||||||
:
|
|
||||||
done
|
|
||||||
fi
|
|
||||||
|
|
||||||
$1
|
|
||||||
|
|
||||||
)
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
# Check if Python 2
|
||||||
|
python2_check() {
|
||||||
|
VERSION="$1"
|
||||||
|
|
||||||
|
version_gte "$VERSION" "python-2.7.0" && version_gt "python-3.0.0" "$VERSION"
|
||||||
|
}
|
||||||
|
|
||||||
|
# Check if Python 3
|
||||||
|
python3_check() {
|
||||||
|
VERSION="$1"
|
||||||
|
|
||||||
|
version_gte "$VERSION" "python-3.0.0" && version_gt "python-4.0.0" "$VERSION"
|
||||||
|
}
|
||||||
|
|
||||||
|
# Check if Python version needs to install SQLite3
|
||||||
|
python_sqlite3_check() {
|
||||||
|
VERSION="$1"
|
||||||
|
MIN_PYTHON_3="python-3.5.6"
|
||||||
|
MIN_PYTHON_2="python-2.7.15"
|
||||||
|
|
||||||
|
( python2_check "$VERSION" && version_gte "$VERSION" "$MIN_PYTHON_2" ) \
|
||||||
|
|| ( python3_check "$VERSION" && version_gte "$VERSION" "$MIN_PYTHON_3" )
|
||||||
|
}
|
||||||
|
|||||||
@@ -1,3 +1,4 @@
|
|||||||
|
#!/usr/bin/env bash
|
||||||
shopt -s extglob
|
shopt -s extglob
|
||||||
|
|
||||||
old-platform() {
|
old-platform() {
|
||||||
@@ -7,6 +8,7 @@ old-platform() {
|
|||||||
puts-warn "This caused the security warning you saw above during the 'pip install' step."
|
puts-warn "This caused the security warning you saw above during the 'pip install' step."
|
||||||
puts-warn "We recommend '$RECOMMENDED_PYTHON_VERSION', which you can specify in a 'runtime.txt' file."
|
puts-warn "We recommend '$RECOMMENDED_PYTHON_VERSION', which you can specify in a 'runtime.txt' file."
|
||||||
puts-warn " -- Much Love, Heroku."
|
puts-warn " -- Much Love, Heroku."
|
||||||
|
mcount 'warnings.python.old'
|
||||||
fi
|
fi
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -16,6 +18,7 @@ pylibmc-missing() {
|
|||||||
puts-warn "Hello! There was a problem with your build related to libmemcache."
|
puts-warn "Hello! There was a problem with your build related to libmemcache."
|
||||||
puts-warn "The Python library 'pylibmc' must be explicitly specified in 'requirements.txt' in order to build correctly."
|
puts-warn "The Python library 'pylibmc' must be explicitly specified in 'requirements.txt' in order to build correctly."
|
||||||
puts-warn "Once you do that, everything should work as expected. -- Much Love, Heroku."
|
puts-warn "Once you do that, everything should work as expected. -- Much Love, Heroku."
|
||||||
|
mcount 'warnings.libmemcache'
|
||||||
fi
|
fi
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -27,6 +30,7 @@ scipy-included() {
|
|||||||
puts-warn "There is, however, a buildpack available that makes it possible to use it on Heroku."
|
puts-warn "There is, however, a buildpack available that makes it possible to use it on Heroku."
|
||||||
puts-warn "You can learn more here: https://devcenter.heroku.com/articles/python-c-deps"
|
puts-warn "You can learn more here: https://devcenter.heroku.com/articles/python-c-deps"
|
||||||
puts-warn "Sorry for the inconvenience. -- Much Love, Heroku."
|
puts-warn "Sorry for the inconvenience. -- Much Love, Heroku."
|
||||||
|
mcount 'warnings.scipy'
|
||||||
fi
|
fi
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -37,6 +41,18 @@ distribute-included() {
|
|||||||
puts-warn "This library is automatically installed by Heroku and shouldn't be in"
|
puts-warn "This library is automatically installed by Heroku and shouldn't be in"
|
||||||
puts-warn "Your requirements.txt file. This can cause unexpected behavior."
|
puts-warn "Your requirements.txt file. This can cause unexpected behavior."
|
||||||
puts-warn " -- Much Love, Heroku."
|
puts-warn " -- Much Love, Heroku."
|
||||||
|
mcount 'warnings.distribute'
|
||||||
|
fi
|
||||||
|
}
|
||||||
|
|
||||||
|
six-included() {
|
||||||
|
if grep -qi 'Running setup.py install for six' "$WARNINGS_LOG"; then
|
||||||
|
echo
|
||||||
|
puts-warn "Hello! Your requirements.txt file contains the six package."
|
||||||
|
puts-warn "This library is automatically installed by Heroku and shouldn't be in"
|
||||||
|
puts-warn "Your requirements.txt file. This can cause unexpected behavior."
|
||||||
|
puts-warn " -- Much Love, Heroku."
|
||||||
|
mcount 'warnings.six'
|
||||||
fi
|
fi
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -45,5 +61,6 @@ show-warnings() {
|
|||||||
pylibmc-missing
|
pylibmc-missing
|
||||||
scipy-included
|
scipy-included
|
||||||
distribute-included
|
distribute-included
|
||||||
|
six-included
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
@@ -0,0 +1,13 @@
|
|||||||
|
[buildpack]
|
||||||
|
name = "Python"
|
||||||
|
|
||||||
|
[publish.Ignore]
|
||||||
|
files = [
|
||||||
|
"test/",
|
||||||
|
".gitignore",
|
||||||
|
".dockerignore",
|
||||||
|
".github/",
|
||||||
|
"Dockerfile",
|
||||||
|
"Pipfile",
|
||||||
|
"Pipfile.lock"
|
||||||
|
]
|
||||||
@@ -1,5 +1,7 @@
|
|||||||
# Python Buildpack Binaries
|
# Python Buildpack Binaries
|
||||||
|
|
||||||
|
For Cedar-14 stack
|
||||||
|
------------------
|
||||||
|
|
||||||
To get started with it, create an app on Heroku inside a clone of this repository, and set your S3 config vars:
|
To get started with it, create an app on Heroku inside a clone of this repository, and set your S3 config vars:
|
||||||
|
|
||||||
@@ -28,4 +30,12 @@ If this works, run `bob deploy` instead of `bob build` to have the result upload
|
|||||||
|
|
||||||
To speed things up drastically, it'll usually be a good idea to `heroku run bash --size PX` instead.
|
To speed things up drastically, it'll usually be a good idea to `heroku run bash --size PX` instead.
|
||||||
|
|
||||||
|
For Heroku-16 stack
|
||||||
|
-------------------
|
||||||
|
|
||||||
|
1. Ensure GNU Make and Docker are installed.
|
||||||
|
2. From the root of the buildpack repository, run: `make buildenv-heroku-16`
|
||||||
|
3. Follow the instructions displayed!
|
||||||
|
|
||||||
|
|
||||||
Enjoy :)
|
Enjoy :)
|
||||||
@@ -3,7 +3,7 @@
|
|||||||
|
|
||||||
OUT_PREFIX=$1
|
OUT_PREFIX=$1
|
||||||
|
|
||||||
echo "Building SQLite..."
|
echo "Building SQLite…"
|
||||||
|
|
||||||
|
|
||||||
SOURCE_TARBALL='https://www.sqlite.org/sqlite-autoconf-3070900.tar.gz'
|
SOURCE_TARBALL='https://www.sqlite.org/sqlite-autoconf-3070900.tar.gz'
|
||||||
|
|||||||
Vendored
+5
-4
@@ -8,16 +8,17 @@ export PATH="/app/.heroku/python/bin/:$PATH"
|
|||||||
hash -r
|
hash -r
|
||||||
|
|
||||||
|
|
||||||
echo "Building gdal..."
|
echo "Building gdal…"
|
||||||
|
|
||||||
SOURCE_TARBALL='http://download.osgeo.org/gdal/1.11.1/gdal-1.11.1.tar.gz'
|
VERSION="2.2.1"
|
||||||
|
SOURCE_TARBALL="http://download.osgeo.org/gdal/${VERSION}/gdal-${VERSION}.tar.gz"
|
||||||
|
|
||||||
curl -L $SOURCE_TARBALL | tar zx
|
curl -L $SOURCE_TARBALL | tar zx
|
||||||
|
|
||||||
cd gdal-1.11.1
|
pushd "gdal-${VERSION}"
|
||||||
./configure --prefix=$OUT_PREFIX --enable-static=no &&
|
./configure --prefix=$OUT_PREFIX --enable-static=no &&
|
||||||
make
|
make
|
||||||
make install
|
make install
|
||||||
|
|
||||||
# Cleanup
|
# Cleanup
|
||||||
cd ..
|
popd
|
||||||
|
|||||||
Vendored
+6
-4
@@ -8,16 +8,18 @@ export PATH="/app/.heroku/python/bin/:$PATH"
|
|||||||
hash -r
|
hash -r
|
||||||
|
|
||||||
|
|
||||||
echo "Building geos..."
|
echo "Building geos…"
|
||||||
|
|
||||||
SOURCE_TARBALL='http://download.osgeo.org/geos/geos-3.4.3.tar.bz2'
|
VERSION=3.6.2
|
||||||
|
|
||||||
|
SOURCE_TARBALL="http://download.osgeo.org/geos/geos-${VERSION}.tar.bz2"
|
||||||
|
|
||||||
curl -L $SOURCE_TARBALL | tar xj
|
curl -L $SOURCE_TARBALL | tar xj
|
||||||
|
|
||||||
cd geos-3.4.3
|
pushd "geos-${VERSION}"
|
||||||
./configure --prefix=$OUT_PREFIX --enable-static=no &&
|
./configure --prefix=$OUT_PREFIX --enable-static=no &&
|
||||||
make
|
make
|
||||||
make install
|
make install
|
||||||
|
|
||||||
# Cleanup
|
# Cleanup
|
||||||
cd ..
|
popd
|
||||||
|
|||||||
Vendored
+1
-1
@@ -13,7 +13,7 @@ export PATH="/app/.heroku/python/bin/:$PATH"
|
|||||||
hash -r
|
hash -r
|
||||||
|
|
||||||
|
|
||||||
echo "Building libffi..."
|
echo "Building libffi…"
|
||||||
|
|
||||||
SOURCE_TARBALL='ftp://sourceware.org/pub/libffi/libffi-3.1.tar.gz'
|
SOURCE_TARBALL='ftp://sourceware.org/pub/libffi/libffi-3.1.tar.gz'
|
||||||
|
|
||||||
|
|||||||
Vendored
+2
-2
@@ -20,7 +20,7 @@ dep_archive_name=${dep_dirname}.tar.gz
|
|||||||
dep_url=https://launchpad.net/libmemcached/1.0/${dep_version}/+download/${dep_archive_name}
|
dep_url=https://launchpad.net/libmemcached/1.0/${dep_version}/+download/${dep_archive_name}
|
||||||
|
|
||||||
# SASL Support.
|
# SASL Support.
|
||||||
echo "-----> Building cyrus-sasl 2.1.26..."
|
echo "-----> Building cyrus-sasl 2.1.26…"
|
||||||
|
|
||||||
curl -LO ftp://ftp.cyrusimap.org/cyrus-sasl/cyrus-sasl-2.1.26.tar.gz
|
curl -LO ftp://ftp.cyrusimap.org/cyrus-sasl/cyrus-sasl-2.1.26.tar.gz
|
||||||
# FTP doesn't play well with piping into tar xz
|
# FTP doesn't play well with piping into tar xz
|
||||||
@@ -33,7 +33,7 @@ make -s -j 9
|
|||||||
make install -s
|
make install -s
|
||||||
popd
|
popd
|
||||||
|
|
||||||
echo "-----> Building libmemcached ${dep_version}..."
|
echo "-----> Building libmemcached ${dep_version}…"
|
||||||
|
|
||||||
curl -L ${dep_url} | tar xz
|
curl -L ${dep_url} | tar xz
|
||||||
pushd ${dep_dirname}
|
pushd ${dep_dirname}
|
||||||
|
|||||||
Vendored
+6
-5
@@ -8,16 +8,17 @@ export PATH="/app/.heroku/python/bin/:$PATH"
|
|||||||
hash -r
|
hash -r
|
||||||
|
|
||||||
|
|
||||||
echo "Building gdal..."
|
echo "Building gdal…"
|
||||||
|
|
||||||
SOURCE_TARBALL='http://download.osgeo.org/proj/proj-4.8.0.tar.gz'
|
VERSION=4.9.3
|
||||||
|
SOURCE_TARBALL="http://download.osgeo.org/proj/proj-${VERSION}.tar.gz"
|
||||||
|
|
||||||
curl -L $SOURCE_TARBALL | tar zx
|
curl -L $SOURCE_TARBALL | tar zx
|
||||||
|
|
||||||
cd proj-4.8.0
|
pushd "proj-${VERSION}"
|
||||||
./configure --prefix=$OUT_PREFIX --enable-static=no &&
|
./configure --prefix=$OUT_PREFIX --enable-static=no
|
||||||
make
|
make
|
||||||
make install
|
make install
|
||||||
|
|
||||||
# Cleanup
|
# Cleanup
|
||||||
cd ..
|
popd
|
||||||
|
|||||||
@@ -6,7 +6,7 @@
|
|||||||
|
|
||||||
OUT_PREFIX=$1
|
OUT_PREFIX=$1
|
||||||
|
|
||||||
echo "Building PyPy..."
|
echo "Building PyPy…"
|
||||||
SOURCE_TARBALL='https://bitbucket.org/pypy/pypy/downloads/pypy2-v5.3.1-linux64.tar.bz2'
|
SOURCE_TARBALL='https://bitbucket.org/pypy/pypy/downloads/pypy2-v5.3.1-linux64.tar.bz2'
|
||||||
curl -L $SOURCE_TARBALL | tar jx
|
curl -L $SOURCE_TARBALL | tar jx
|
||||||
cp -R pypy2-v5.3.1-linux64/* $OUT_PREFIX
|
cp -R pypy2-v5.3.1-linux64/* $OUT_PREFIX
|
||||||
|
|||||||
@@ -6,7 +6,7 @@
|
|||||||
|
|
||||||
OUT_PREFIX=$1
|
OUT_PREFIX=$1
|
||||||
|
|
||||||
echo "Building PyPy..."
|
echo "Building PyPy…"
|
||||||
SOURCE_TARBALL='https://bitbucket.org/pypy/pypy/downloads/pypy2-v5.6.0-linux64.tar.bz2'
|
SOURCE_TARBALL='https://bitbucket.org/pypy/pypy/downloads/pypy2-v5.6.0-linux64.tar.bz2'
|
||||||
curl -L $SOURCE_TARBALL | tar jx
|
curl -L $SOURCE_TARBALL | tar jx
|
||||||
cp -R pypy2-v5.6.0-linux64/* $OUT_PREFIX
|
cp -R pypy2-v5.6.0-linux64/* $OUT_PREFIX
|
||||||
|
|||||||
Executable
+14
@@ -0,0 +1,14 @@
|
|||||||
|
#!/usr/bin/env bash
|
||||||
|
# Build Path: /app/.heroku/python/
|
||||||
|
# Build Deps: libraries/sqlite
|
||||||
|
|
||||||
|
# NOTICE: This formula only works for the cedar-14 and heroku-16 stacks, not cedar.
|
||||||
|
|
||||||
|
OUT_PREFIX=$1
|
||||||
|
|
||||||
|
echo "Building PyPy…"
|
||||||
|
SOURCE_TARBALL='https://bitbucket.org/pypy/pypy/downloads/pypy2-v5.7.0-linux64.tar.bz2'
|
||||||
|
curl -L $SOURCE_TARBALL | tar jx
|
||||||
|
cp -R pypy2-v5.7.0-linux64/* $OUT_PREFIX
|
||||||
|
|
||||||
|
ln $OUT_PREFIX/bin/pypy $OUT_PREFIX/bin/python
|
||||||
Executable
+14
@@ -0,0 +1,14 @@
|
|||||||
|
#!/usr/bin/env bash
|
||||||
|
# Build Path: /app/.heroku/python/
|
||||||
|
# Build Deps: libraries/sqlite
|
||||||
|
|
||||||
|
# NOTICE: This formula only works for the cedar-14 stack, not cedar.
|
||||||
|
|
||||||
|
OUT_PREFIX=$1
|
||||||
|
|
||||||
|
echo "Building PyPy…"
|
||||||
|
SOURCE_TARBALL='https://bitbucket.org/pypy/pypy/downloads/pypy2-v5.7.1-linux64.tar.bz2'
|
||||||
|
curl -L $SOURCE_TARBALL | tar jx
|
||||||
|
cp -R pypy2-v5.7.1-linux64/* $OUT_PREFIX
|
||||||
|
|
||||||
|
ln $OUT_PREFIX/bin/pypy $OUT_PREFIX/bin/python
|
||||||
Executable
+12
@@ -0,0 +1,12 @@
|
|||||||
|
#!/usr/bin/env bash
|
||||||
|
# Build Path: /app/.heroku/python/
|
||||||
|
# Build Deps: libraries/sqlite
|
||||||
|
|
||||||
|
OUT_PREFIX=$1
|
||||||
|
|
||||||
|
echo "Building PyPy…"
|
||||||
|
SOURCE_TARBALL='https://bitbucket.org/pypy/pypy/downloads/pypy2-v5.8.0-linux64.tar.bz2'
|
||||||
|
curl -L $SOURCE_TARBALL | tar jx
|
||||||
|
cp -R pypy2-v5.8.0-linux64/* $OUT_PREFIX
|
||||||
|
|
||||||
|
ln $OUT_PREFIX/bin/pypy $OUT_PREFIX/bin/python
|
||||||
@@ -6,7 +6,7 @@
|
|||||||
|
|
||||||
OUT_PREFIX=$1
|
OUT_PREFIX=$1
|
||||||
|
|
||||||
echo "Building PyPy..."
|
echo "Building PyPy…"
|
||||||
SOURCE_TARBALL='https://bitbucket.org/pypy/pypy/downloads/pypy3-2.4.0-linux64.tar.bz2'
|
SOURCE_TARBALL='https://bitbucket.org/pypy/pypy/downloads/pypy3-2.4.0-linux64.tar.bz2'
|
||||||
curl -L $SOURCE_TARBALL | tar jx
|
curl -L $SOURCE_TARBALL | tar jx
|
||||||
cp -R pypy3-2.4.0-linux64/* $OUT_PREFIX
|
cp -R pypy3-2.4.0-linux64/* $OUT_PREFIX
|
||||||
|
|||||||
@@ -6,7 +6,7 @@
|
|||||||
|
|
||||||
OUT_PREFIX=$1
|
OUT_PREFIX=$1
|
||||||
|
|
||||||
echo "Building PyPy..."
|
echo "Building PyPy…"
|
||||||
SOURCE_TARBALL='https://bitbucket.org/pypy/pypy/downloads/pypy3.3-v5.5.0-alpha-linux64.tar.bz2'
|
SOURCE_TARBALL='https://bitbucket.org/pypy/pypy/downloads/pypy3.3-v5.5.0-alpha-linux64.tar.bz2'
|
||||||
curl -L $SOURCE_TARBALL | tar jx
|
curl -L $SOURCE_TARBALL | tar jx
|
||||||
cp -R pypy3-v5.5.0-linux64/* $OUT_PREFIX
|
cp -R pypy3-v5.5.0-linux64/* $OUT_PREFIX
|
||||||
|
|||||||
Executable
+12
@@ -0,0 +1,12 @@
|
|||||||
|
#!/usr/bin/env bash
|
||||||
|
# Build Path: /app/.heroku/python/
|
||||||
|
# Build Deps: libraries/sqlite
|
||||||
|
|
||||||
|
OUT_PREFIX=$1
|
||||||
|
|
||||||
|
echo "Building PyPy…"
|
||||||
|
SOURCE_TARBALL='https://bitbucket.org/pypy/pypy/downloads/pypy3-v5.7.1-linux64.tar.bz2'
|
||||||
|
curl -L $SOURCE_TARBALL | tar jx
|
||||||
|
cp -R pypy3-v5.7.1-linux64/* $OUT_PREFIX
|
||||||
|
|
||||||
|
ln $OUT_PREFIX/bin/pypy3 $OUT_PREFIX/bin/python
|
||||||
Executable
+12
@@ -0,0 +1,12 @@
|
|||||||
|
#!/usr/bin/env bash
|
||||||
|
# Build Path: /app/.heroku/python/
|
||||||
|
# Build Deps: libraries/sqlite
|
||||||
|
|
||||||
|
OUT_PREFIX=$1
|
||||||
|
|
||||||
|
echo "Building PyPy…"
|
||||||
|
SOURCE_TARBALL='https://bitbucket.org/pypy/pypy/downloads/pypy3-v5.8.0-linux64.tar.bz2'
|
||||||
|
curl -L $SOURCE_TARBALL | tar jx
|
||||||
|
cp -R pypy3-v5.8.0-linux64/* $OUT_PREFIX
|
||||||
|
|
||||||
|
ln $OUT_PREFIX/bin/pypy3 $OUT_PREFIX/bin/python
|
||||||
@@ -4,7 +4,7 @@
|
|||||||
|
|
||||||
OUT_PREFIX=$1
|
OUT_PREFIX=$1
|
||||||
|
|
||||||
echo "Building Python..."
|
echo "Building Python…"
|
||||||
SOURCE_TARBALL='https://python.org/ftp/python/2.7.10/Python-2.7.10.tgz'
|
SOURCE_TARBALL='https://python.org/ftp/python/2.7.10/Python-2.7.10.tgz'
|
||||||
curl -L $SOURCE_TARBALL | tar xz
|
curl -L $SOURCE_TARBALL | tar xz
|
||||||
mv Python-2.7.10 src
|
mv Python-2.7.10 src
|
||||||
|
|||||||
@@ -4,7 +4,7 @@
|
|||||||
|
|
||||||
OUT_PREFIX=$1
|
OUT_PREFIX=$1
|
||||||
|
|
||||||
echo "Building Python..."
|
echo "Building Python…"
|
||||||
SOURCE_TARBALL='https://python.org/ftp/python/2.7.11/Python-2.7.11.tgz'
|
SOURCE_TARBALL='https://python.org/ftp/python/2.7.11/Python-2.7.11.tgz'
|
||||||
curl -L $SOURCE_TARBALL | tar xz
|
curl -L $SOURCE_TARBALL | tar xz
|
||||||
mv Python-2.7.11 src
|
mv Python-2.7.11 src
|
||||||
|
|||||||
@@ -4,7 +4,7 @@
|
|||||||
|
|
||||||
OUT_PREFIX=$1
|
OUT_PREFIX=$1
|
||||||
|
|
||||||
echo "Building Python..."
|
echo "Building Python…"
|
||||||
SOURCE_TARBALL='https://python.org/ftp/python/2.7.12/Python-2.7.12.tgz'
|
SOURCE_TARBALL='https://python.org/ftp/python/2.7.12/Python-2.7.12.tgz'
|
||||||
curl -L $SOURCE_TARBALL | tar xz
|
curl -L $SOURCE_TARBALL | tar xz
|
||||||
mv Python-2.7.12 src
|
mv Python-2.7.12 src
|
||||||
|
|||||||
@@ -4,7 +4,7 @@
|
|||||||
|
|
||||||
OUT_PREFIX=$1
|
OUT_PREFIX=$1
|
||||||
|
|
||||||
echo "Building Python..."
|
echo "Building Python…"
|
||||||
SOURCE_TARBALL='https://python.org/ftp/python/2.7.13/Python-2.7.13.tgz'
|
SOURCE_TARBALL='https://python.org/ftp/python/2.7.13/Python-2.7.13.tgz'
|
||||||
curl -L $SOURCE_TARBALL | tar xz
|
curl -L $SOURCE_TARBALL | tar xz
|
||||||
mv Python-2.7.13 src
|
mv Python-2.7.13 src
|
||||||
@@ -13,3 +13,7 @@ cd src
|
|||||||
./configure --prefix=$OUT_PREFIX --enable-unicode=ucs4 --with-ensurepip=no
|
./configure --prefix=$OUT_PREFIX --enable-unicode=ucs4 --with-ensurepip=no
|
||||||
make
|
make
|
||||||
make install
|
make install
|
||||||
|
|
||||||
|
# Remove unneeded test directories, similar to the official Docker Python images:
|
||||||
|
# https://github.com/docker-library/python
|
||||||
|
find "${OUT_PREFIX}" \( -type d -a \( -name test -o -name tests \) \) -exec rm -rf '{}' +
|
||||||
|
|||||||
Executable
+19
@@ -0,0 +1,19 @@
|
|||||||
|
#!/usr/bin/env bash
|
||||||
|
# Build Path: /app/.heroku/python/
|
||||||
|
# Build Deps: libraries/sqlite
|
||||||
|
|
||||||
|
OUT_PREFIX=$1
|
||||||
|
|
||||||
|
echo "Building Python…"
|
||||||
|
SOURCE_TARBALL='https://python.org/ftp/python/2.7.14/Python-2.7.14.tgz'
|
||||||
|
curl -L $SOURCE_TARBALL | tar xz
|
||||||
|
mv Python-2.7.14 src
|
||||||
|
cd src
|
||||||
|
|
||||||
|
./configure --prefix=$OUT_PREFIX --enable-unicode=ucs4 --with-ensurepip=no
|
||||||
|
make
|
||||||
|
make install
|
||||||
|
|
||||||
|
# Remove unneeded test directories, similar to the official Docker Python images:
|
||||||
|
# https://github.com/docker-library/python
|
||||||
|
find "${OUT_PREFIX}" \( -type d -a \( -name test -o -name tests \) \) -exec rm -rf '{}' +
|
||||||
Executable
+27
@@ -0,0 +1,27 @@
|
|||||||
|
#!/usr/bin/env bash
|
||||||
|
# Build Path: /app/.heroku/python/
|
||||||
|
|
||||||
|
OUT_PREFIX=$1
|
||||||
|
BIN_DIR="$(cd "$(dirname "$0")"/../.. || exit; pwd)/bin"
|
||||||
|
export BIN_DIR
|
||||||
|
|
||||||
|
# shellcheck source=bin/utils
|
||||||
|
source "$BIN_DIR/steps/sqlite3"
|
||||||
|
|
||||||
|
sqlite3_version
|
||||||
|
echo "Setting up SQLite3 Headers for $SQLITE3_VERSION"
|
||||||
|
sqlite3_install "$OUT_PREFIX" "$SQLITE3_VERSION" 1
|
||||||
|
|
||||||
|
echo "Building Python…"
|
||||||
|
SOURCE_TARBALL='https://python.org/ftp/python/2.7.15/Python-2.7.15.tgz'
|
||||||
|
curl -L $SOURCE_TARBALL | tar xz
|
||||||
|
mv Python-2.7.15 src
|
||||||
|
cd src
|
||||||
|
|
||||||
|
./configure --prefix=$OUT_PREFIX --enable-unicode=ucs4 --with-ensurepip=no
|
||||||
|
make
|
||||||
|
make install
|
||||||
|
|
||||||
|
# Remove unneeded test directories, similar to the official Docker Python images:
|
||||||
|
# https://github.com/docker-library/python
|
||||||
|
find "${OUT_PREFIX}" \( -type d -a \( -name test -o -name tests \) \) -exec rm -rf '{}' +
|
||||||
@@ -4,7 +4,7 @@
|
|||||||
|
|
||||||
OUT_PREFIX=$1
|
OUT_PREFIX=$1
|
||||||
|
|
||||||
echo "Building Python..."
|
echo "Building Python…"
|
||||||
SOURCE_TARBALL='https://python.org/ftp/python/2.7.9/Python-2.7.9.tgz'
|
SOURCE_TARBALL='https://python.org/ftp/python/2.7.9/Python-2.7.9.tgz'
|
||||||
curl -L $SOURCE_TARBALL | tar xz
|
curl -L $SOURCE_TARBALL | tar xz
|
||||||
mv Python-2.7.9 src
|
mv Python-2.7.9 src
|
||||||
|
|||||||
Executable
+32
@@ -0,0 +1,32 @@
|
|||||||
|
#!/usr/bin/env bash
|
||||||
|
# Build Path: /app/.heroku/python/
|
||||||
|
|
||||||
|
OUT_PREFIX=$1
|
||||||
|
BIN_DIR="$(cd "$(dirname "$0")"/../.. || exit; pwd)/bin"
|
||||||
|
export BIN_DIR
|
||||||
|
|
||||||
|
# shellcheck source=bin/utils
|
||||||
|
source "$BIN_DIR/steps/sqlite3"
|
||||||
|
|
||||||
|
sqlite3_version
|
||||||
|
echo "Setting up SQLite3 Headers for $SQLITE3_VERSION"
|
||||||
|
sqlite3_install "$OUT_PREFIX" "$SQLITE3_VERSION" 1
|
||||||
|
|
||||||
|
echo "Building Python…"
|
||||||
|
SOURCE_TARBALL='https://python.org/ftp/python/3.4.9/Python-3.4.9.tgz'
|
||||||
|
curl -L $SOURCE_TARBALL | tar xz
|
||||||
|
mv Python-3.4.9 src
|
||||||
|
cd src
|
||||||
|
|
||||||
|
./configure --prefix=$OUT_PREFIX --with-ensurepip=no
|
||||||
|
make
|
||||||
|
make install
|
||||||
|
|
||||||
|
# Remove unneeded test directories, similar to the official Docker Python images:
|
||||||
|
# https://github.com/docker-library/python
|
||||||
|
find "${OUT_PREFIX}" \( -type d -a \( -name test -o -name tests \) \) -exec rm -rf '{}' +
|
||||||
|
|
||||||
|
# Remove spare /
|
||||||
|
LOCATION=${OUT_PREFIX%?}
|
||||||
|
|
||||||
|
ln $LOCATION/bin/python3 $LOCATION/bin/python
|
||||||
@@ -4,7 +4,7 @@
|
|||||||
|
|
||||||
OUT_PREFIX=$1
|
OUT_PREFIX=$1
|
||||||
|
|
||||||
echo "Building Python..."
|
echo "Building Python…"
|
||||||
SOURCE_TARBALL='https://python.org/ftp/python/3.5.2/Python-3.5.2.tgz'
|
SOURCE_TARBALL='https://python.org/ftp/python/3.5.2/Python-3.5.2.tgz'
|
||||||
curl -L $SOURCE_TARBALL | tar xz
|
curl -L $SOURCE_TARBALL | tar xz
|
||||||
mv Python-3.5.2 src
|
mv Python-3.5.2 src
|
||||||
|
|||||||
Executable
+18
@@ -0,0 +1,18 @@
|
|||||||
|
#!/usr/bin/env bash
|
||||||
|
# Build Path: /app/.heroku/python/
|
||||||
|
# Build Deps: libraries/sqlite
|
||||||
|
|
||||||
|
OUT_PREFIX=$1
|
||||||
|
|
||||||
|
echo "Building Python…"
|
||||||
|
SOURCE_TARBALL='https://python.org/ftp/python/3.5.3/Python-3.5.3.tgz'
|
||||||
|
curl -L $SOURCE_TARBALL | tar xz
|
||||||
|
mv Python-3.5.3 src
|
||||||
|
cd src
|
||||||
|
|
||||||
|
./configure --prefix=$OUT_PREFIX --with-ensurepip=no
|
||||||
|
make
|
||||||
|
make install
|
||||||
|
|
||||||
|
# ln $OUT_PREFIX/bin/python3 $OUT_PREFIX/bin/python
|
||||||
|
|
||||||
Executable
+32
@@ -0,0 +1,32 @@
|
|||||||
|
#!/usr/bin/env bash
|
||||||
|
# Build Path: /app/.heroku/python/
|
||||||
|
|
||||||
|
OUT_PREFIX=$1
|
||||||
|
BIN_DIR="$(cd "$(dirname "$0")"/../.. || exit; pwd)/bin"
|
||||||
|
export BIN_DIR
|
||||||
|
|
||||||
|
# shellcheck source=bin/utils
|
||||||
|
source "$BIN_DIR/steps/sqlite3"
|
||||||
|
|
||||||
|
sqlite3_version
|
||||||
|
echo "Setting up SQLite3 Headers for $SQLITE3_VERSION"
|
||||||
|
sqlite3_install "$OUT_PREFIX" "$SQLITE3_VERSION" 1
|
||||||
|
|
||||||
|
echo "Building Python…"
|
||||||
|
SOURCE_TARBALL='https://python.org/ftp/python/3.5.6/Python-3.5.6.tgz'
|
||||||
|
curl -L $SOURCE_TARBALL | tar xz
|
||||||
|
mv Python-3.5.6 src
|
||||||
|
cd src
|
||||||
|
|
||||||
|
./configure --prefix=$OUT_PREFIX --with-ensurepip=no
|
||||||
|
make
|
||||||
|
make install
|
||||||
|
|
||||||
|
# Remove unneeded test directories, similar to the official Docker Python images:
|
||||||
|
# https://github.com/docker-library/python
|
||||||
|
find "${OUT_PREFIX}" \( -type d -a \( -name test -o -name tests \) \) -exec rm -rf '{}' +
|
||||||
|
|
||||||
|
# Remove spare /
|
||||||
|
LOCATION=${OUT_PREFIX%?}
|
||||||
|
|
||||||
|
ln $LOCATION/bin/python3 $LOCATION/bin/python
|
||||||
@@ -4,7 +4,7 @@
|
|||||||
|
|
||||||
OUT_PREFIX=$1
|
OUT_PREFIX=$1
|
||||||
|
|
||||||
echo "Building Python..."
|
echo "Building Python…"
|
||||||
SOURCE_TARBALL='https://python.org/ftp/python/3.6.0/Python-3.6.0.tgz'
|
SOURCE_TARBALL='https://python.org/ftp/python/3.6.0/Python-3.6.0.tgz'
|
||||||
curl -L $SOURCE_TARBALL | tar xz
|
curl -L $SOURCE_TARBALL | tar xz
|
||||||
mv Python-3.6.0 src
|
mv Python-3.6.0 src
|
||||||
|
|||||||
Executable
+18
@@ -0,0 +1,18 @@
|
|||||||
|
#!/usr/bin/env bash
|
||||||
|
# Build Path: /app/.heroku/python/
|
||||||
|
# Build Deps: libraries/sqlite
|
||||||
|
|
||||||
|
OUT_PREFIX=$1
|
||||||
|
|
||||||
|
echo "Building Python…"
|
||||||
|
SOURCE_TARBALL='https://python.org/ftp/python/3.6.1/Python-3.6.1.tgz'
|
||||||
|
curl -L $SOURCE_TARBALL | tar xz
|
||||||
|
mv Python-3.6.1 src
|
||||||
|
cd src
|
||||||
|
|
||||||
|
./configure --prefix=$OUT_PREFIX --with-ensurepip=no
|
||||||
|
make
|
||||||
|
make install
|
||||||
|
|
||||||
|
ln $OUT_PREFIX/bin/python3 $OUT_PREFIX/bin/python
|
||||||
|
|
||||||
Executable
+21
@@ -0,0 +1,21 @@
|
|||||||
|
#!/usr/bin/env bash
|
||||||
|
# Build Path: /app/.heroku/python/
|
||||||
|
# Build Deps: libraries/sqlite
|
||||||
|
|
||||||
|
OUT_PREFIX=$1
|
||||||
|
|
||||||
|
echo "Building Python…"
|
||||||
|
SOURCE_TARBALL='https://python.org/ftp/python/3.6.2/Python-3.6.2.tgz'
|
||||||
|
curl -L $SOURCE_TARBALL | tar xz
|
||||||
|
mv Python-3.6.2 src
|
||||||
|
cd src
|
||||||
|
|
||||||
|
./configure --prefix=$OUT_PREFIX --with-ensurepip=no
|
||||||
|
make
|
||||||
|
make install
|
||||||
|
|
||||||
|
# Remove unneeded test directories, similar to the official Docker Python images:
|
||||||
|
# https://github.com/docker-library/python
|
||||||
|
find "${OUT_PREFIX}" \( -type d -a \( -name test -o -name tests \) \) -exec rm -rf '{}' +
|
||||||
|
|
||||||
|
ln $OUT_PREFIX/bin/python3 $OUT_PREFIX/bin/python
|
||||||
Executable
+21
@@ -0,0 +1,21 @@
|
|||||||
|
#!/usr/bin/env bash
|
||||||
|
# Build Path: /app/.heroku/python/
|
||||||
|
# Build Deps: libraries/sqlite
|
||||||
|
|
||||||
|
OUT_PREFIX=$1
|
||||||
|
|
||||||
|
echo "Building Python…"
|
||||||
|
SOURCE_TARBALL='https://python.org/ftp/python/3.6.3/Python-3.6.3.tgz'
|
||||||
|
curl -L $SOURCE_TARBALL | tar xz
|
||||||
|
mv Python-3.6.3 src
|
||||||
|
cd src
|
||||||
|
|
||||||
|
./configure --prefix=$OUT_PREFIX --with-ensurepip=no
|
||||||
|
make
|
||||||
|
make install
|
||||||
|
|
||||||
|
# Remove unneeded test directories, similar to the official Docker Python images:
|
||||||
|
# https://github.com/docker-library/python
|
||||||
|
find "${OUT_PREFIX}" \( -type d -a \( -name test -o -name tests \) \) -exec rm -rf '{}' +
|
||||||
|
|
||||||
|
ln $OUT_PREFIX/bin/python3 $OUT_PREFIX/bin/python
|
||||||
Executable
+21
@@ -0,0 +1,21 @@
|
|||||||
|
#!/usr/bin/env bash
|
||||||
|
# Build Path: /app/.heroku/python/
|
||||||
|
# Build Deps: libraries/sqlite
|
||||||
|
|
||||||
|
OUT_PREFIX=$1
|
||||||
|
|
||||||
|
echo "Building Python…"
|
||||||
|
SOURCE_TARBALL='https://python.org/ftp/python/3.6.4/Python-3.6.4.tgz'
|
||||||
|
curl -L $SOURCE_TARBALL | tar xz
|
||||||
|
mv Python-3.6.4 src
|
||||||
|
cd src
|
||||||
|
|
||||||
|
./configure --prefix=$OUT_PREFIX --with-ensurepip=no
|
||||||
|
make
|
||||||
|
make install
|
||||||
|
|
||||||
|
# Remove unneeded test directories, similar to the official Docker Python images:
|
||||||
|
# https://github.com/docker-library/python
|
||||||
|
find "${OUT_PREFIX}" \( -type d -a \( -name test -o -name tests \) \) -exec rm -rf '{}' +
|
||||||
|
|
||||||
|
ln $OUT_PREFIX/bin/python3 $OUT_PREFIX/bin/python
|
||||||
Executable
+21
@@ -0,0 +1,21 @@
|
|||||||
|
#!/usr/bin/env bash
|
||||||
|
# Build Path: /app/.heroku/python/
|
||||||
|
# Build Deps: libraries/sqlite
|
||||||
|
|
||||||
|
OUT_PREFIX=$1
|
||||||
|
|
||||||
|
echo "Building Python…"
|
||||||
|
SOURCE_TARBALL='https://python.org/ftp/python/3.6.5/Python-3.6.5.tgz'
|
||||||
|
curl -L $SOURCE_TARBALL | tar xz
|
||||||
|
mv Python-3.6.5 src
|
||||||
|
cd src
|
||||||
|
|
||||||
|
./configure --prefix=$OUT_PREFIX --with-ensurepip=no
|
||||||
|
make
|
||||||
|
make install
|
||||||
|
|
||||||
|
# Remove unneeded test directories, similar to the official Docker Python images:
|
||||||
|
# https://github.com/docker-library/python
|
||||||
|
find "${OUT_PREFIX}" \( -type d -a \( -name test -o -name tests \) \) -exec rm -rf '{}' +
|
||||||
|
|
||||||
|
ln $OUT_PREFIX/bin/python3 $OUT_PREFIX/bin/python
|
||||||
Executable
+29
@@ -0,0 +1,29 @@
|
|||||||
|
#!/usr/bin/env bash
|
||||||
|
# Build Path: /app/.heroku/python/
|
||||||
|
|
||||||
|
OUT_PREFIX=$1
|
||||||
|
BIN_DIR="$(cd "$(dirname "$0")"/../.. || exit; pwd)/bin"
|
||||||
|
export BIN_DIR
|
||||||
|
|
||||||
|
# shellcheck source=bin/utils
|
||||||
|
source "$BIN_DIR/steps/sqlite3"
|
||||||
|
|
||||||
|
sqlite3_version
|
||||||
|
echo "Setting up SQLite3 Headers for $SQLITE3_VERSION"
|
||||||
|
sqlite3_install "$OUT_PREFIX" "$SQLITE3_VERSION" 1
|
||||||
|
|
||||||
|
echo "Building Python…"
|
||||||
|
SOURCE_TARBALL='https://python.org/ftp/python/3.6.6/Python-3.6.6.tgz'
|
||||||
|
curl -L $SOURCE_TARBALL | tar xz
|
||||||
|
mv Python-3.6.6 src
|
||||||
|
cd src
|
||||||
|
|
||||||
|
./configure --prefix=$OUT_PREFIX --with-ensurepip=no
|
||||||
|
make
|
||||||
|
make install
|
||||||
|
|
||||||
|
# Remove unneeded test directories, similar to the official Docker Python images:
|
||||||
|
# https://github.com/docker-library/python
|
||||||
|
find "${OUT_PREFIX}" \( -type d -a \( -name test -o -name tests \) \) -exec rm -rf '{}' +
|
||||||
|
|
||||||
|
ln $OUT_PREFIX/bin/python3 $OUT_PREFIX/bin/python
|
||||||
Executable
+32
@@ -0,0 +1,32 @@
|
|||||||
|
#!/usr/bin/env bash
|
||||||
|
# Build Path: /app/.heroku/python/
|
||||||
|
|
||||||
|
OUT_PREFIX=$1
|
||||||
|
BIN_DIR="$(cd "$(dirname "$0")"/../.. || exit; pwd)/bin"
|
||||||
|
export BIN_DIR
|
||||||
|
|
||||||
|
# shellcheck source=bin/utils
|
||||||
|
source "$BIN_DIR/steps/sqlite3"
|
||||||
|
|
||||||
|
sqlite3_version
|
||||||
|
echo "Setting up SQLite3 Headers for $SQLITE3_VERSION"
|
||||||
|
sqlite3_install "$OUT_PREFIX" "$SQLITE3_VERSION" 1
|
||||||
|
|
||||||
|
echo "Building Python…"
|
||||||
|
SOURCE_TARBALL='https://python.org/ftp/python/3.6.7/Python-3.6.7.tgz'
|
||||||
|
curl -L $SOURCE_TARBALL | tar xz
|
||||||
|
mv Python-3.6.7 src
|
||||||
|
cd src
|
||||||
|
|
||||||
|
./configure --prefix=$OUT_PREFIX --with-ensurepip=no
|
||||||
|
make
|
||||||
|
make install
|
||||||
|
|
||||||
|
# Remove unneeded test directories, similar to the official Docker Python images:
|
||||||
|
# https://github.com/docker-library/python
|
||||||
|
find "${OUT_PREFIX}" \( -type d -a \( -name test -o -name tests \) \) -exec rm -rf '{}' +
|
||||||
|
|
||||||
|
# Remove spare /
|
||||||
|
LOCATION=${OUT_PREFIX%?}
|
||||||
|
|
||||||
|
ln $LOCATION/bin/python3 $LOCATION/bin/python
|
||||||
Executable
+29
@@ -0,0 +1,29 @@
|
|||||||
|
#!/usr/bin/env bash
|
||||||
|
# Build Path: /app/.heroku/python/
|
||||||
|
|
||||||
|
OUT_PREFIX=$1
|
||||||
|
BIN_DIR="$(cd "$(dirname "$0")"/../.. || exit; pwd)/bin"
|
||||||
|
export BIN_DIR
|
||||||
|
|
||||||
|
# shellcheck source=bin/utils
|
||||||
|
source "$BIN_DIR/steps/sqlite3"
|
||||||
|
|
||||||
|
sqlite3_version
|
||||||
|
echo "Setting up SQLite3 Headers for $SQLITE3_VERSION"
|
||||||
|
sqlite3_install "$OUT_PREFIX" "$SQLITE3_VERSION" 1
|
||||||
|
|
||||||
|
echo "Building Python…"
|
||||||
|
SOURCE_TARBALL='https://python.org/ftp/python/3.7.0/Python-3.7.0.tgz'
|
||||||
|
curl -L $SOURCE_TARBALL | tar xz
|
||||||
|
mv Python-3.7.0 src
|
||||||
|
cd src
|
||||||
|
|
||||||
|
./configure --prefix=$OUT_PREFIX --with-ensurepip=no
|
||||||
|
make
|
||||||
|
make install
|
||||||
|
|
||||||
|
# Remove unneeded test directories, similar to the official Docker Python images:
|
||||||
|
# https://github.com/docker-library/python
|
||||||
|
find "${OUT_PREFIX}" \( -type d -a \( -name test -o -name tests \) \) -exec rm -rf '{}' +
|
||||||
|
|
||||||
|
ln $OUT_PREFIX/bin/python3 $OUT_PREFIX/bin/python
|
||||||
Executable
+32
@@ -0,0 +1,32 @@
|
|||||||
|
#!/usr/bin/env bash
|
||||||
|
# Build Path: /app/.heroku/python/
|
||||||
|
|
||||||
|
OUT_PREFIX=$1
|
||||||
|
BIN_DIR="$(cd "$(dirname "$0")"/../.. || exit; pwd)/bin"
|
||||||
|
export BIN_DIR
|
||||||
|
|
||||||
|
# shellcheck source=bin/utils
|
||||||
|
source "$BIN_DIR/steps/sqlite3"
|
||||||
|
|
||||||
|
sqlite3_version
|
||||||
|
echo "Setting up SQLite3 Headers for $SQLITE3_VERSION"
|
||||||
|
sqlite3_install "$OUT_PREFIX" "$SQLITE3_VERSION" 1
|
||||||
|
|
||||||
|
echo "Building Python…"
|
||||||
|
SOURCE_TARBALL='https://python.org/ftp/python/3.7.1/Python-3.7.1.tgz'
|
||||||
|
curl -L $SOURCE_TARBALL | tar xz
|
||||||
|
mv Python-3.7.1 src
|
||||||
|
cd src
|
||||||
|
|
||||||
|
./configure --prefix=$OUT_PREFIX --with-ensurepip=no
|
||||||
|
make
|
||||||
|
make install
|
||||||
|
|
||||||
|
# Remove unneeded test directories, similar to the official Docker Python images:
|
||||||
|
# https://github.com/docker-library/python
|
||||||
|
find "${OUT_PREFIX}" \( -type d -a \( -name test -o -name tests \) \) -exec rm -rf '{}' +
|
||||||
|
|
||||||
|
# Remove spare /
|
||||||
|
LOCATION=${OUT_PREFIX%?}
|
||||||
|
|
||||||
|
ln $LOCATION/bin/python3 $LOCATION/bin/python
|
||||||
Executable
+5
@@ -0,0 +1,5 @@
|
|||||||
|
#!/usr/bin/env bash
|
||||||
|
|
||||||
|
sudo apt-get -qq update
|
||||||
|
sudo apt-get install software-properties-common
|
||||||
|
curl --fail --retry 3 --retry-delay 1 --connect-timeout 3 --max-time 30 https://cli-assets.heroku.com/install-ubuntu.sh | sh
|
||||||
@@ -0,0 +1,38 @@
|
|||||||
|
#!/bin/bash
|
||||||
|
|
||||||
|
set -e
|
||||||
|
|
||||||
|
BP_NAME=${1:-"heroku/python"}
|
||||||
|
|
||||||
|
curVersion=$(heroku buildpacks:versions "$BP_NAME" | awk 'FNR == 3 { print $1 }')
|
||||||
|
newVersion="v$((curVersion + 1))"
|
||||||
|
|
||||||
|
read -p "Deploy as version: $newVersion [y/n]? " choice
|
||||||
|
case "$choice" in
|
||||||
|
y|Y ) echo "";;
|
||||||
|
n|N ) exit 0;;
|
||||||
|
* ) exit 1;;
|
||||||
|
esac
|
||||||
|
|
||||||
|
originMaster=$(git rev-parse origin/master)
|
||||||
|
echo "Tagging commit $originMaster with $newVersion... "
|
||||||
|
git tag "$newVersion" "${originMaster:?}"
|
||||||
|
git push origin refs/tags/$newVersion
|
||||||
|
|
||||||
|
heroku buildpacks:publish "$BP_NAME" "$newVersion"
|
||||||
|
|
||||||
|
if [ $(git tag | grep -q previous-version) ]; then
|
||||||
|
echo "Updating previous-version tag"
|
||||||
|
git tag -d previous-version
|
||||||
|
git push origin :previous-version
|
||||||
|
git tag previous-version latest-version
|
||||||
|
fi
|
||||||
|
if [ $(git tag | grep -q latest-version) ]; then
|
||||||
|
echo "Updating latest-version tag"
|
||||||
|
git tag -d latest-version
|
||||||
|
git push origin :latest-version
|
||||||
|
git tag latest-version "${originMaster:?}"
|
||||||
|
git push --tags
|
||||||
|
fi
|
||||||
|
|
||||||
|
echo "Done."
|
||||||
@@ -0,0 +1,5 @@
|
|||||||
|
{
|
||||||
|
"python": [
|
||||||
|
"heroku/python-getting-started"
|
||||||
|
]
|
||||||
|
}
|
||||||
@@ -0,0 +1,3 @@
|
|||||||
|
---
|
||||||
|
- - "./repos/python/python-getting-started"
|
||||||
|
- f56b90499ec11e1c9576da2f8c7331300e189db3
|
||||||
+3
-1
@@ -1 +1,3 @@
|
|||||||
bob-builder==0.0.5
|
docopt==0.6.2
|
||||||
|
bob-builder
|
||||||
|
boto==2.48.0
|
||||||
|
|||||||
@@ -0,0 +1,10 @@
|
|||||||
|
require_relative '../spec_helper'
|
||||||
|
|
||||||
|
describe "Python!!!!!!!!!!!" do
|
||||||
|
it "🐍" do
|
||||||
|
Hatchet::Runner.new('python-getting-started', stack: DEFAULT_STACK).deploy do |app|
|
||||||
|
expect(app.output).to match(/Installing pip/)
|
||||||
|
expect(app.run('python -V')).to match(/3.6.6/)
|
||||||
|
end
|
||||||
|
end
|
||||||
|
end
|
||||||
@@ -0,0 +1,23 @@
|
|||||||
|
ENV['HATCHET_BUILDPACK_BASE'] = 'https://github.com/' + ENV['TRAVIS_REPO_SLUG'] + '.git'
|
||||||
|
|
||||||
|
require 'rspec/core'
|
||||||
|
require 'rspec/retry'
|
||||||
|
require 'hatchet'
|
||||||
|
|
||||||
|
require 'date'
|
||||||
|
|
||||||
|
RSpec.configure do |config|
|
||||||
|
config.full_backtrace = true
|
||||||
|
config.verbose_retry = true # show retry status in spec process
|
||||||
|
config.default_retry_count = 2 if ENV['IS_RUNNING_ON_CI'] # retry all tests that fail again
|
||||||
|
config.expect_with :rspec do |c|
|
||||||
|
c.syntax = :expect
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
if ENV['TRAVIS']
|
||||||
|
# Don't execute tests against "merge" commits
|
||||||
|
exit 0 if ENV['TRAVIS_PULL_REQUEST'] != 'false' && ENV['TRAVIS_BRANCH'] == 'master'
|
||||||
|
end
|
||||||
|
|
||||||
|
DEFAULT_STACK = 'heroku-16'
|
||||||
+1
@@ -0,0 +1 @@
|
|||||||
|
apache-airflow==1.10
|
||||||
Vendored
+1
@@ -0,0 +1 @@
|
|||||||
|
cffi
|
||||||
@@ -0,0 +1,5 @@
|
|||||||
|
venv
|
||||||
|
*.pyc
|
||||||
|
staticfiles
|
||||||
|
.env
|
||||||
|
db.sqlite3
|
||||||
Vendored
+16
@@ -0,0 +1,16 @@
|
|||||||
|
[[source]]
|
||||||
|
|
||||||
|
url = "https://pypi.python.org/simple"
|
||||||
|
verify_ssl = true
|
||||||
|
|
||||||
|
|
||||||
|
[packages]
|
||||||
|
|
||||||
|
django = "*"
|
||||||
|
gunicorn = "*"
|
||||||
|
django-heroku = "*"
|
||||||
|
|
||||||
|
|
||||||
|
[requires]
|
||||||
|
|
||||||
|
python_version = "3.6"
|
||||||
+118
@@ -0,0 +1,118 @@
|
|||||||
|
{
|
||||||
|
"_meta": {
|
||||||
|
"hash": {
|
||||||
|
"sha256": "7843aa61794626156c5dbfa26d6be61df24889c396f04a8dead353d23e2899d6"
|
||||||
|
},
|
||||||
|
"host-environment-markers": {
|
||||||
|
"implementation_name": "cpython",
|
||||||
|
"implementation_version": "3.6.3",
|
||||||
|
"os_name": "posix",
|
||||||
|
"platform_machine": "x86_64",
|
||||||
|
"platform_python_implementation": "CPython",
|
||||||
|
"platform_release": "17.3.0",
|
||||||
|
"platform_system": "Darwin",
|
||||||
|
"platform_version": "Darwin Kernel Version 17.3.0: Thu Nov 9 18:09:22 PST 2017; root:xnu-4570.31.3~1/RELEASE_X86_64",
|
||||||
|
"python_full_version": "3.6.3",
|
||||||
|
"python_version": "3.6",
|
||||||
|
"sys_platform": "darwin"
|
||||||
|
},
|
||||||
|
"pipfile-spec": 6,
|
||||||
|
"requires": {
|
||||||
|
"python_version": "3.6"
|
||||||
|
},
|
||||||
|
"sources": [
|
||||||
|
{
|
||||||
|
"url": "https://pypi.python.org/simple",
|
||||||
|
"verify_ssl": true
|
||||||
|
}
|
||||||
|
]
|
||||||
|
},
|
||||||
|
"default": {
|
||||||
|
"dj-database-url": {
|
||||||
|
"hashes": [
|
||||||
|
"sha256:e16d94c382ea0564c48038fa7fe8d9c890ef1ab1a8ec4cb48e732c124b9482fd",
|
||||||
|
"sha256:a6832d8445ee9d788c5baa48aef8130bf61fdc442f7d9a548424d25cd85c9f08"
|
||||||
|
],
|
||||||
|
"version": "==0.4.2"
|
||||||
|
},
|
||||||
|
"django": {
|
||||||
|
"hashes": [
|
||||||
|
"sha256:af18618ce3291be5092893d8522fe3919661bf3a1fb60e3858ae74865a4f07c2",
|
||||||
|
"sha256:9614851d4a7ff8cbd32b73c6076441f377c45a5bbff7e771798fb02c43c31f47"
|
||||||
|
],
|
||||||
|
"version": "==2.0"
|
||||||
|
},
|
||||||
|
"django-heroku": {
|
||||||
|
"hashes": [
|
||||||
|
"sha256:193bacbe644a607642f6b60acd0a382d6abf4a1f7578f8d3eb10659457efe904",
|
||||||
|
"sha256:af6c723872553b7427121a865eb9fce70d566b9ad26d7defcdcd03a8acea56c8"
|
||||||
|
],
|
||||||
|
"version": "==0.1.0"
|
||||||
|
},
|
||||||
|
"gunicorn": {
|
||||||
|
"hashes": [
|
||||||
|
"sha256:75af03c99389535f218cc596c7de74df4763803f7b63eb09d77e92b3956b36c6",
|
||||||
|
"sha256:eee1169f0ca667be05db3351a0960765620dad53f53434262ff8901b68a1b622"
|
||||||
|
],
|
||||||
|
"version": "==19.7.1"
|
||||||
|
},
|
||||||
|
"psycopg2": {
|
||||||
|
"hashes": [
|
||||||
|
"sha256:594aa9a095de16614f703d759e10c018bdffeafce2921b8e80a0e8a0ebbc12e5",
|
||||||
|
"sha256:1cf5d84290c771eeecb734abe2c6c3120e9837eb12f99474141a862b9061ac51",
|
||||||
|
"sha256:0344b181e1aea37a58c218ccb0f0f771295de9aa25a625ed076e6996c6530f9e",
|
||||||
|
"sha256:25250867a4cd1510fb755ef9cb38da3065def999d8e92c44e49a39b9b76bc893",
|
||||||
|
"sha256:317612d5d0ca4a9f7e42afb2add69b10be360784d21ce4ecfbca19f1f5eadf43",
|
||||||
|
"sha256:9d6266348b15b4a48623bf4d3e50445d8e581da413644f365805b321703d0fac",
|
||||||
|
"sha256:ddca39cc55877653b5fcf59976d073e3d58c7c406ef54ae8e61ddf8782867182",
|
||||||
|
"sha256:988d2ec7560d42ef0ac34b3b97aad14c4f068792f00e1524fa1d3749fe4e4b64",
|
||||||
|
"sha256:7a9c6c62e6e05df5406e9b5235c31c376a22620ef26715a663cee57083b3c2ea",
|
||||||
|
"sha256:7a75565181e75ba0b9fb174b58172bf6ea9b4331631cfe7bafff03f3641f5d73",
|
||||||
|
"sha256:94e4128ba1ea56f02522fffac65520091a9de3f5c00da31539e085e13db4771b",
|
||||||
|
"sha256:92179bd68c2efe72924a99b6745a9172471931fc296f9bfdf9645b75eebd6344",
|
||||||
|
"sha256:b9358e203168fef7bfe9f430afaed3a2a624717a1d19c7afa7dfcbd76e3cd95c",
|
||||||
|
"sha256:009e0bc09a57dbef4b601cb8b46a2abad51f5274c8be4bba276ff2884cd4cc53",
|
||||||
|
"sha256:d3ac07240e2304181ffdb13c099840b5eb555efc7be9344503c0c03aa681de79",
|
||||||
|
"sha256:40fa5630cd7d237cd93c4d4b64b9e5ed9273d1cfce55241c7f9066f5db70629d",
|
||||||
|
"sha256:6c2f1a76a9ebd9ecf7825b9e20860139ca502c2bf1beabf6accf6c9e66a7e0c3",
|
||||||
|
"sha256:37f54452c7787dbdc0a634ca9773362b91709917f0b365ed14b831f03cbd34ba",
|
||||||
|
"sha256:8f5942a4daf1ffac42109dc4a72f786af4baa4fa702ede1d7c57b4b696c2e7d6",
|
||||||
|
"sha256:bf708455cd1e9fa96c05126e89a0c59b200d086c7df7bbafc7d9be769e4149a3",
|
||||||
|
"sha256:82c40ea3ac1555e0462803380609fbe8b26f52620f3d4f8eb480cfd8ceed8a14",
|
||||||
|
"sha256:207ba4f9125a0a4200691e82d5eee7ea1485708eabe99a07fc7f08696fae62f4",
|
||||||
|
"sha256:0cd4c848f0e9d805d531e44973c8f48962e20eb7fc0edac3db4f9dbf9ed5ab82",
|
||||||
|
"sha256:57baf63aeb2965ca4b52613ce78e968b6d2bde700c97f6a7e8c6c236b51ab83e",
|
||||||
|
"sha256:2954557393cfc9a5c11a5199c7a78cd9c0c793a047552d27b1636da50d013916",
|
||||||
|
"sha256:7c31dade89634807196a6b20ced831fbd5bec8a21c4e458ea950c9102c3aa96f",
|
||||||
|
"sha256:1286dd16d0e46d59fa54582725986704a7a3f3d9aca6c5902a7eceb10c60cb7e",
|
||||||
|
"sha256:697ff63bc5451e0b0db48ad205151123d25683b3754198be7ab5fcb44334e519",
|
||||||
|
"sha256:fc993c9331d91766d54757bbc70231e29d5ceb2d1ac08b1570feaa0c38ab9582",
|
||||||
|
"sha256:9d64fed2681552ed642e9c0cc831a9e95ab91de72b47d0cb68b5bf506ba88647",
|
||||||
|
"sha256:5c3213be557d0468f9df8fe2487eaf2990d9799202c5ff5cb8d394d09fad9b2a"
|
||||||
|
],
|
||||||
|
"version": "==2.7.3.2"
|
||||||
|
},
|
||||||
|
"pytz": {
|
||||||
|
"hashes": [
|
||||||
|
"sha256:80af0f3008046b9975242012a985f04c5df1f01eed4ec1633d56cc47a75a6a48",
|
||||||
|
"sha256:feb2365914948b8620347784b6b6da356f31c9d03560259070b2f30cff3d469d",
|
||||||
|
"sha256:59707844a9825589878236ff2f4e0dc9958511b7ffaae94dc615da07d4a68d33",
|
||||||
|
"sha256:d0ef5ef55ed3d37854320d4926b04a4cb42a2e88f71da9ddfdacfde8e364f027",
|
||||||
|
"sha256:c41c62827ce9cafacd6f2f7018e4f83a6f1986e87bfd000b8cfbd4ab5da95f1a",
|
||||||
|
"sha256:8cc90340159b5d7ced6f2ba77694d946fc975b09f1a51d93f3ce3bb399396f94",
|
||||||
|
"sha256:dd2e4ca6ce3785c8dd342d1853dd9052b19290d5bf66060846e5dc6b8d6667f7",
|
||||||
|
"sha256:699d18a2a56f19ee5698ab1123bbcc1d269d061996aeb1eda6d89248d3542b82",
|
||||||
|
"sha256:fae4cffc040921b8a2d60c6cf0b5d662c1190fe54d718271db4eb17d44a185b7"
|
||||||
|
],
|
||||||
|
"version": "==2017.3"
|
||||||
|
},
|
||||||
|
"whitenoise": {
|
||||||
|
"hashes": [
|
||||||
|
"sha256:15f43b2e701821b95c9016cf469d29e2a546cb1c7dead584ba82c36f843995cf",
|
||||||
|
"sha256:9d81515f2b5b27051910996e1e860b1332e354d9e7bcf30c98f21dcb6713e0dd"
|
||||||
|
],
|
||||||
|
"version": "==3.3.1"
|
||||||
|
}
|
||||||
|
},
|
||||||
|
"develop": {}
|
||||||
|
}
|
||||||
Vendored
+1
@@ -0,0 +1 @@
|
|||||||
|
web: gunicorn gettingstarted.wsgi
|
||||||
@@ -0,0 +1 @@
|
|||||||
|
web: python manage.py runserver 0.0.0.0:5000
|
||||||
+44
@@ -0,0 +1,44 @@
|
|||||||
|
# Python: Getting Started
|
||||||
|
|
||||||
|
A barebones Django app, which can easily be deployed to Heroku.
|
||||||
|
|
||||||
|
This application supports the [Getting Started with Python on Heroku](https://devcenter.heroku.com/articles/getting-started-with-python) article - check it out.
|
||||||
|
|
||||||
|
## Running Locally
|
||||||
|
|
||||||
|
Make sure you have Python [installed properly](http://install.python-guide.org). Also, install the [Heroku CLI](https://devcenter.heroku.com/articles/heroku-cli) and [Postgres](https://devcenter.heroku.com/articles/heroku-postgresql#local-setup).
|
||||||
|
|
||||||
|
```sh
|
||||||
|
$ git clone git@github.com:heroku/python-getting-started.git
|
||||||
|
$ cd python-getting-started
|
||||||
|
|
||||||
|
$ pipenv install
|
||||||
|
|
||||||
|
$ createdb python_getting_started
|
||||||
|
|
||||||
|
$ python manage.py migrate
|
||||||
|
$ python manage.py collectstatic
|
||||||
|
|
||||||
|
$ heroku local
|
||||||
|
```
|
||||||
|
|
||||||
|
Your app should now be running on [localhost:5000](http://localhost:5000/).
|
||||||
|
|
||||||
|
## Deploying to Heroku
|
||||||
|
|
||||||
|
```sh
|
||||||
|
$ heroku create
|
||||||
|
$ git push heroku master
|
||||||
|
|
||||||
|
$ heroku run python manage.py migrate
|
||||||
|
$ heroku open
|
||||||
|
```
|
||||||
|
or
|
||||||
|
|
||||||
|
[](https://heroku.com/deploy)
|
||||||
|
|
||||||
|
## Documentation
|
||||||
|
|
||||||
|
For more information about using Python on Heroku, see these Dev Center articles:
|
||||||
|
|
||||||
|
- [Python on Heroku](https://devcenter.heroku.com/categories/python)
|
||||||
Vendored
+22
@@ -0,0 +1,22 @@
|
|||||||
|
{
|
||||||
|
"name": "Start on Heroku: Python",
|
||||||
|
"description": "A barebones Python app, which can easily be deployed to Heroku.",
|
||||||
|
"image": "heroku/python",
|
||||||
|
"repository": "https://github.com/heroku/python-getting-started",
|
||||||
|
"keywords": ["python", "django" ],
|
||||||
|
"addons": [ "heroku-postgresql" ],
|
||||||
|
"env": {
|
||||||
|
"SECRET_KEY": {
|
||||||
|
"description": "The secret key for the Django application.",
|
||||||
|
"generator": "secret"
|
||||||
|
}
|
||||||
|
},
|
||||||
|
"environments": {
|
||||||
|
"test": {
|
||||||
|
"scripts": {
|
||||||
|
"test-setup": "python manage.py collectstatic --noinput",
|
||||||
|
"test": "python manage.py test"
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
@@ -0,0 +1,125 @@
|
|||||||
|
"""
|
||||||
|
Django settings for gettingstarted project.
|
||||||
|
|
||||||
|
Generated by 'django-admin startproject' using Django 2.0.
|
||||||
|
|
||||||
|
For more information on this file, see
|
||||||
|
https://docs.djangoproject.com/en/2.0/topics/settings/
|
||||||
|
|
||||||
|
For the full list of settings and their values, see
|
||||||
|
https://docs.djangoproject.com/en/2.0/ref/settings/
|
||||||
|
"""
|
||||||
|
|
||||||
|
import os
|
||||||
|
import django_heroku
|
||||||
|
|
||||||
|
|
||||||
|
# Build paths inside the project like this: os.path.join(BASE_DIR, ...)
|
||||||
|
BASE_DIR = os.path.dirname(os.path.dirname(os.path.abspath(__file__)))
|
||||||
|
|
||||||
|
|
||||||
|
# Quick-start development settings - unsuitable for production
|
||||||
|
# See https://docs.djangoproject.com/en/2.0/howto/deployment/checklist/
|
||||||
|
|
||||||
|
# SECURITY WARNING: keep the secret key used in production secret!
|
||||||
|
SECRET_KEY = 'CHANGE_ME!!!! (P.S. the SECRET_KEY environment variable will be used, if set, instead).'
|
||||||
|
|
||||||
|
# SECURITY WARNING: don't run with debug turned on in production!
|
||||||
|
DEBUG = True
|
||||||
|
|
||||||
|
ALLOWED_HOSTS = []
|
||||||
|
|
||||||
|
|
||||||
|
# Application definition
|
||||||
|
|
||||||
|
INSTALLED_APPS = [
|
||||||
|
'django.contrib.admin',
|
||||||
|
'django.contrib.auth',
|
||||||
|
'django.contrib.contenttypes',
|
||||||
|
'django.contrib.sessions',
|
||||||
|
'django.contrib.messages',
|
||||||
|
'django.contrib.staticfiles',
|
||||||
|
'hello'
|
||||||
|
]
|
||||||
|
|
||||||
|
MIDDLEWARE = [
|
||||||
|
'django.middleware.security.SecurityMiddleware',
|
||||||
|
'django.contrib.sessions.middleware.SessionMiddleware',
|
||||||
|
'django.middleware.common.CommonMiddleware',
|
||||||
|
'django.middleware.csrf.CsrfViewMiddleware',
|
||||||
|
'django.contrib.auth.middleware.AuthenticationMiddleware',
|
||||||
|
'django.contrib.messages.middleware.MessageMiddleware',
|
||||||
|
'django.middleware.clickjacking.XFrameOptionsMiddleware',
|
||||||
|
]
|
||||||
|
|
||||||
|
ROOT_URLCONF = 'gettingstarted.urls'
|
||||||
|
|
||||||
|
TEMPLATES = [
|
||||||
|
{
|
||||||
|
'BACKEND': 'django.template.backends.django.DjangoTemplates',
|
||||||
|
'DIRS': [],
|
||||||
|
'APP_DIRS': True,
|
||||||
|
'OPTIONS': {
|
||||||
|
'context_processors': [
|
||||||
|
'django.template.context_processors.debug',
|
||||||
|
'django.template.context_processors.request',
|
||||||
|
'django.contrib.auth.context_processors.auth',
|
||||||
|
'django.contrib.messages.context_processors.messages',
|
||||||
|
],
|
||||||
|
},
|
||||||
|
},
|
||||||
|
]
|
||||||
|
|
||||||
|
WSGI_APPLICATION = 'gettingstarted.wsgi.application'
|
||||||
|
|
||||||
|
|
||||||
|
# Database
|
||||||
|
# https://docs.djangoproject.com/en/2.0/ref/settings/#databases
|
||||||
|
|
||||||
|
DATABASES = {
|
||||||
|
'default': {
|
||||||
|
'ENGINE': 'django.db.backends.sqlite3',
|
||||||
|
'NAME': os.path.join(BASE_DIR, 'db.sqlite3'),
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
# Password validation
|
||||||
|
# https://docs.djangoproject.com/en/2.0/ref/settings/#auth-password-validators
|
||||||
|
|
||||||
|
AUTH_PASSWORD_VALIDATORS = [
|
||||||
|
{
|
||||||
|
'NAME': 'django.contrib.auth.password_validation.UserAttributeSimilarityValidator',
|
||||||
|
},
|
||||||
|
{
|
||||||
|
'NAME': 'django.contrib.auth.password_validation.MinimumLengthValidator',
|
||||||
|
},
|
||||||
|
{
|
||||||
|
'NAME': 'django.contrib.auth.password_validation.CommonPasswordValidator',
|
||||||
|
},
|
||||||
|
{
|
||||||
|
'NAME': 'django.contrib.auth.password_validation.NumericPasswordValidator',
|
||||||
|
},
|
||||||
|
]
|
||||||
|
|
||||||
|
|
||||||
|
# Internationalization
|
||||||
|
# https://docs.djangoproject.com/en/2.0/topics/i18n/
|
||||||
|
|
||||||
|
LANGUAGE_CODE = 'en-us'
|
||||||
|
|
||||||
|
TIME_ZONE = 'UTC'
|
||||||
|
|
||||||
|
USE_I18N = True
|
||||||
|
|
||||||
|
USE_L10N = True
|
||||||
|
|
||||||
|
USE_TZ = True
|
||||||
|
|
||||||
|
|
||||||
|
# Static files (CSS, JavaScript, Images)
|
||||||
|
# https://docs.djangoproject.com/en/2.0/howto/static-files/
|
||||||
|
|
||||||
|
STATIC_URL = '/static/'
|
||||||
|
|
||||||
|
django_heroku.settings(locals())
|
||||||
@@ -0,0 +1,17 @@
|
|||||||
|
from django.conf.urls import include, url
|
||||||
|
from django.urls import path
|
||||||
|
|
||||||
|
from django.contrib import admin
|
||||||
|
admin.autodiscover()
|
||||||
|
|
||||||
|
import hello.views
|
||||||
|
|
||||||
|
# Examples:
|
||||||
|
# url(r'^$', 'gettingstarted.views.home', name='home'),
|
||||||
|
# url(r'^blog/', include('blog.urls')),
|
||||||
|
|
||||||
|
urlpatterns = [
|
||||||
|
url(r'^$', hello.views.index, name='index'),
|
||||||
|
url(r'^db', hello.views.db, name='db'),
|
||||||
|
path('admin/', admin.site.urls),
|
||||||
|
]
|
||||||
Some files were not shown because too many files have changed in this diff Show More
Reference in New Issue
Block a user