CircleCI не выбирает переменную среды, определенную на этапе выполнения? - PullRequest
0 голосов
/ 31 мая 2018

Я пытаюсь запустить тесты 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?Что-то не так с моим синтаксисом или пониманием документации?

1 Ответ

0 голосов
/ 05 октября 2018

У меня была похожая проблема с помощью circleCI + GAE;переменные, которые, как я думал, я устанавливал в .circleCI / config.yml, никогда не попадают в приложение, потому что процесс сборки, запущенный GAE, не передает их. Вместо этого мне нужно было:

  • makeнесколько файлов app.yaml (в моем случае app-staging.yaml и app-prod.yaml)
  • обновите .circleci / config.yml, чтобы использовать их в каждом операторе команды, например:

    команда: gcloud app deploy app-staging.yaml

...