mirror of
https://github.com/cookiecutter/cookiecutter-django.git
synced 2024-11-10 19:57:09 +03:00
53 lines
1.9 KiB
Bash
Executable File
53 lines
1.9 KiB
Bash
Executable File
#!/bin/sh
|
|
# this is a very simple script that tests the docker configuration for cookiecutter-django
|
|
# it is meant to be run from the root directory of the repository, eg:
|
|
# sh tests/test_docker.sh
|
|
|
|
set -o errexit
|
|
set -x
|
|
|
|
# create a cache directory
|
|
mkdir -p .cache/docker
|
|
cd .cache/docker
|
|
|
|
# create the project using the default settings in cookiecutter.json
|
|
cookiecutter ../../ --no-input --overwrite-if-exists use_docker=y "$@"
|
|
cd my_awesome_project
|
|
|
|
# make sure all images build
|
|
docker compose -f docker-compose.local.yml build
|
|
|
|
# run the project's type checks
|
|
docker compose -f docker-compose.local.yml run django mypy my_awesome_project
|
|
|
|
# run the project's tests
|
|
docker compose -f docker-compose.local.yml run django pytest
|
|
|
|
# return non-zero status code if there are migrations that have not been created
|
|
docker compose -f docker-compose.local.yml run django python manage.py makemigrations --check || { echo "ERROR: there were changes in the models, but migration listed above have not been created and are not saved in version control"; exit 1; }
|
|
|
|
# Test support for translations
|
|
docker compose -f docker-compose.local.yml run django python manage.py makemessages --all
|
|
|
|
# Make sure the check doesn't raise any warnings
|
|
docker compose -f docker-compose.local.yml run \
|
|
-e DJANGO_SECRET_KEY="$(openssl rand -base64 64)" \
|
|
-e REDIS_URL=redis://redis:6379/0 \
|
|
-e CELERY_BROKER_URL=redis://redis:6379/0 \
|
|
-e DJANGO_AWS_ACCESS_KEY_ID=x \
|
|
-e DJANGO_AWS_SECRET_ACCESS_KEY=x \
|
|
-e DJANGO_AWS_STORAGE_BUCKET_NAME=x \
|
|
-e DJANGO_ADMIN_URL=x \
|
|
-e MAILGUN_API_KEY=x \
|
|
-e MAILGUN_DOMAIN=x \
|
|
django python manage.py check --settings=config.settings.production --deploy --database default --fail-level WARNING
|
|
|
|
# Generate the HTML for the documentation
|
|
docker compose -f docker-compose.docs.yml run docs make html
|
|
|
|
# Run npm build script if package.json is present
|
|
if [ -f "package.json" ]
|
|
then
|
|
docker compose -f docker-compose.local.yml run node npm run build
|
|
fi
|