Do you have the heart of the cards?. Check out the project's documentation.
Start the dev server for local development:
docker-compose up
Run a command inside the docker container:
docker-compose run --rm web [command]
To create a superuser to view endpoints on 127.0.0.1:8000:
docker-compose up -d
docker exec -i -t holdtheline_web_1 python manage.py createsuperuser
Deployment is automated via Travis. When builds pass on the master or qa branch, Travis will deploy that branch to Heroku. Follow these steps to enable this feature.
Initialize the production server:
heroku create holdtheline-prod --remote prod && \
heroku addons:create newrelic:wayne --app holdtheline-prod && \
heroku addons:create heroku-postgresql:hobby-dev --app holdtheline-prod && \
heroku config:set DJANGO_SECRET_KEY=`openssl rand -base64 32` \
DJANGO_AWS_ACCESS_KEY_ID="Add your id" \
DJANGO_AWS_SECRET_ACCESS_KEY="Add your key" \
DJANGO_AWS_STORAGE_BUCKET_NAME="holdtheline-prod" \
DJANGO_CONFIGURATION="Production" \
DJANGO_SETTINGS_MODULE="holdtheline.config" \
--app holdtheline-prod
Initialize the qa server:
heroku create holdtheline-qa --remote qa && \
heroku addons:create newrelic:wayne --app holdtheline-qa && \
heroku addons:create heroku-postgresql:hobby-dev --app holdtheline-qa && \
heroku config:set DJANGO_SECRET_KEY=`openssl rand -base64 32` \
DJANGO_AWS_ACCESS_KEY_ID="Add your id" \
DJANGO_AWS_SECRET_ACCESS_KEY="Add your key" \
DJANGO_AWS_STORAGE_BUCKET_NAME="holdtheline-qa" \
DJANGO_CONFIGURATION="Production" \
DJANGO_SETTINGS_MODULE="holdtheline.config" \
--app holdtheline-qa
Securely add your Heroku credentials to Travis so that it can automatically deploy your changes:
travis encrypt HEROKU_AUTH_TOKEN="$(heroku auth:token)" --add
Commit your changes and push to master and qa to trigger your first deploys:
git commit -a -m "ci(travis): add Heroku credentials" && \
git push origin master:qa && \
git push origin master
You're now ready to continuously ship! ✨ 💅 🛳