summaryrefslogtreecommitdiff
path: root/src/mailman/database
diff options
context:
space:
mode:
authorAbhilash Raj2015-01-10 05:12:56 +0530
committerAbhilash Raj2015-01-10 05:12:56 +0530
commitc2cb944fbfebc017bddbbe81563ef18a28fbbe6f (patch)
tree05175387670ebf6349493961e79a101e30d37a35 /src/mailman/database
parent7023082164c5ee67cd183b74af0b756707b87818 (diff)
downloadmailman-c2cb944fbfebc017bddbbe81563ef18a28fbbe6f.tar.gz
mailman-c2cb944fbfebc017bddbbe81563ef18a28fbbe6f.tar.zst
mailman-c2cb944fbfebc017bddbbe81563ef18a28fbbe6f.zip
fix for migration autogeneration using alembic
Diffstat (limited to 'src/mailman/database')
-rw-r--r--src/mailman/database/alembic/env.py9
1 files changed, 7 insertions, 2 deletions
diff --git a/src/mailman/database/alembic/env.py b/src/mailman/database/alembic/env.py
index 5fb9ac138..a039a20e6 100644
--- a/src/mailman/database/alembic/env.py
+++ b/src/mailman/database/alembic/env.py
@@ -25,11 +25,18 @@ __all__ = [
from alembic import context
from contextlib import closing
+from mailman.core.initialize import initialize_1
from mailman.config import config
from mailman.database.model import Model
from mailman.utilities.string import expand
from sqlalchemy import create_engine
+try:
+ url = expand(config.database.url, config.paths)
+except AttributeError:
+ # Initialize config object for external alembic calls
+ initialize_1()
+ url = expand(config.database.url, config.paths)
def run_migrations_offline():
@@ -42,7 +49,6 @@ def run_migrations_offline():
Calls to context.execute() here emit the given string to the script
output.
"""
- url = expand(config.database.url, config.paths)
context.configure(url=url, target_metadata=Model.metadata)
with context.begin_transaction():
context.run_migrations()
@@ -54,7 +60,6 @@ def run_migrations_online():
In this scenario we need to create an Engine and associate a
connection with the context.
"""
- url = expand(config.database.url, config.paths)
engine = create_engine(url)
connection = engine.connect()