Commit 72b4cf37 by Kevin Falcone

Don't hardcode student_module_history

aws_migrate may be used on boxes where that DB does not yet exist.
parent 447c189d
...@@ -13,18 +13,27 @@ from .aws import * ...@@ -13,18 +13,27 @@ from .aws import *
import os import os
from django.core.exceptions import ImproperlyConfigured from django.core.exceptions import ImproperlyConfigured
DB_OVERRIDES = dict(
def get_db_overrides(db_name):
"""
Now that we have multiple databases, we want to look up from the environment
for both databases.
"""
db_overrides = dict(
PASSWORD=os.environ.get('DB_MIGRATION_PASS', None), PASSWORD=os.environ.get('DB_MIGRATION_PASS', None),
ENGINE=os.environ.get('DB_MIGRATION_ENGINE', DATABASES['default']['ENGINE']), ENGINE=os.environ.get('DB_MIGRATION_ENGINE', DATABASES[db_name]['ENGINE']),
USER=os.environ.get('DB_MIGRATION_USER', DATABASES['default']['USER']), USER=os.environ.get('DB_MIGRATION_USER', DATABASES[db_name]['USER']),
NAME=os.environ.get('DB_MIGRATION_NAME', DATABASES['default']['NAME']), NAME=os.environ.get('DB_MIGRATION_NAME', DATABASES[db_name]['NAME']),
HOST=os.environ.get('DB_MIGRATION_HOST', DATABASES['default']['HOST']), HOST=os.environ.get('DB_MIGRATION_HOST', DATABASES[db_name]['HOST']),
PORT=os.environ.get('DB_MIGRATION_PORT', DATABASES['default']['PORT']), PORT=os.environ.get('DB_MIGRATION_PORT', DATABASES[db_name]['PORT']),
) )
if DB_OVERRIDES['PASSWORD'] is None: if db_overrides['PASSWORD'] is None:
raise ImproperlyConfigured("No database password was provided for running " raise ImproperlyConfigured("No database password was provided for running "
"migrations. This is fatal.") "migrations. This is fatal.")
return db_overrides
DATABASES['default'].update(DB_OVERRIDES) for db in DATABASES:
DATABASES['student_module_history'].update(DB_OVERRIDES) # You never migrate a read_replica
if db != 'read_replica':
DATABASES[db].update(get_db_overrides(db))
...@@ -33,5 +33,7 @@ def get_db_overrides(db_name): ...@@ -33,5 +33,7 @@ def get_db_overrides(db_name):
"migrations. This is fatal.") "migrations. This is fatal.")
return db_overrides return db_overrides
for db in ['default', 'student_module_history']: for db in DATABASES:
# You never migrate a read_replica
if db != 'read_replica':
DATABASES[db].update(get_db_overrides(db)) DATABASES[db].update(get_db_overrides(db))
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment