cookiecutter-django/tests/test_docker.sh

52 lines
1.9 KiB
Bash
Raw Normal View History

2016-01-18 13:56:48 +03:00
#!/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
2020-10-04 17:56:17 +03:00
set -x
2016-01-18 13:56:48 +03:00
# create a cache directory
mkdir -p .cache/docker
cd .cache/docker
# create the project using the default settings in cookiecutter.json
uv run cookiecutter ../../ --no-input --overwrite-if-exists use_docker=y "$@"
2018-03-04 15:18:27 +03:00
cd my_awesome_project
2016-01-18 13:56:48 +03:00
2021-11-11 22:21:16 +03:00
# make sure all images build
docker compose -f docker-compose.local.yml build
2021-11-11 22:21:16 +03:00
2019-04-02 17:10:14 +03:00
# run the project's type checks
docker compose -f docker-compose.local.yml run django mypy my_awesome_project
2018-08-19 14:08:29 +03:00
2019-04-02 17:10:14 +03:00
# run the project's tests
docker compose -f docker-compose.local.yml run django pytest
2019-04-02 17:10:14 +03:00
# 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; }
2019-04-02 17:10:14 +03:00
# 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 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