Я пытаюсь запустить тесты CircleCI для проекта Django, в котором manage.py
определяет версию settings.py
для применения (development.py
, staging.py
или production.py
) из переменной среды, ENV_ROLE
.Ранее для ENV_ROLE
было установлено значение по умолчанию development
, если оно не определено, но я нахожусь в процессе его изменения, так что вместо этого Django выдает ошибку ImproperlyConfigured
, если она не определена.
InЧтобы пройти тесты, мне нужно определить переменную окружения ENV_ROLE
в нашей тестовой среде CircleCI.После https://circleci.com/docs/2.0/env-vars/#setting-an-environment-variable-in-a-step, Я добавил следующее к шагу run
:
- run:
environment:
ENV_ROLE: development
Однако, я все еще получаю эту ошибку от CircleCI:
#!/bin/bash -eo pipefail
cd lucy-web
source venv/bin/activate
python manage.py compilescss --verbosity 0
python manage.py collectstatic --clear --no-input --verbosity 0
flake8
python manage.py test
Traceback (most recent call last):
File "/root/lucy/lucy_web/lucy-web/env.py", line 5, in <module>
ENV_ROLE = os.environ['ENV_ROLE']
File "/usr/local/lib/python3.6/os.py", line 669, in __getitem__
raise KeyError(key) from None
KeyError: 'ENV_ROLE'
During handling of the above exception, another exception occurred:
Traceback (most recent call last):
File "manage.py", line 4, in <module>
from env import ENV_ROLE
File "/root/lucy/lucy_web/lucy-web/env.py", line 8, in <module>
"No 'ENV_ROLE' environment variable is defined. "
django.core.exceptions.ImproperlyConfigured: No 'ENV_ROLE' environment variable is defined. Please define it as 'development', 'staging', or 'production'.
Exited with code 1
Здесьявляется полным .circleci/config.yml
:
version: 2
jobs:
build:
working_directory: ~/lucy/lucy_web/
docker:
- image: python:3.6.5
environment:
DATABASE_URL: ...
- image: jannkleen/docker-postgres-gis-hstore
environment:
POSTGRES_USER: ...
POSTGRES_DB: ...
- image: redis:4.0.9-alpine
steps:
- checkout
- restore_cache:
key: deps1-{{ .Branch }}-{{ checksum "lucy-web/requirements.txt" }}
- run:
name: Install Python deps in a venv
command: |
cd lucy-web
python3 -m venv venv
. venv/bin/activate
pip3 install -r requirements.txt
- save_cache:
key: deps1-{{ .Branch }}-{{ checksum "lucy-web/requirements.txt" }}
paths:
- "venv"
- run:
environment:
ENV_ROLE: development
command: |
cd lucy-web
source venv/bin/activate
python manage.py compilescss --verbosity 0
python manage.py collectstatic --clear --no-input --verbosity 0
flake8
python manage.py test
- store_artifacts:
path: test-reports/
destination: tr1
- store_test_results:
path: test-reports/
app_test:
working_directory: ~/lucy/lucy_app
docker:
- image: node:8
steps:
- checkout
- run:
command: |
cd lucy-app
yarn install
yarn lint
yarn jest
workflows:
version: 2
build_and_test:
jobs:
- build
- app_test
Проект Django имеет измененный manage.py
:
#!/usr/bin/env python
import os
import sys
from dotenv import load_dotenv, find_dotenv
if __name__ == "__main__":
# Set environment variables from .env file
load_dotenv(find_dotenv())
# Determine which settings to apply (development, staging, or production)
from env import ENV_ROLE
os.environ.setdefault("DJANGO_SETTINGS_MODULE", f"lucy.settings.{ENV_ROLE}")
try:
from django.core.management import execute_from_command_line
except ImportError:
# The above import may fail for some other reason. Ensure that the
# issue is really that Django is missing to avoid masking other
# exceptions on Python 2.
try:
import django # noqa: F401
except ImportError:
raise ImportError(
"Couldn't import Django. Are you sure it's installed and "
"available on your PYTHONPATH environment variable? Did you "
"forget to activate a virtual environment?"
)
raise
execute_from_command_line(sys.argv)
, где env.py
проверяет, определена ли переменная среды ENV_ROLE
ив противном случае выдает ошибку ImproperlyConfigured
:
import os
from django.core.exceptions import ImproperlyConfigured
try:
ENV_ROLE = os.environ['ENV_ROLE']
except KeyError:
raise ImproperlyConfigured(
"No 'ENV_ROLE' environment variable is defined. "
"Please define it as 'development', 'staging', or 'production'.")
Я не понимаю, почему CircleCI не "подхватывает" переменную среды ENV_ROLE
?Что-то не так с моим синтаксисом или пониманием документации?