При использовании двух баз данных в тестах django применяет миграции к обеим
У меня есть две базы данных: "default" и "logs". "logs" - это MongoDB, которая используется для ведения логов.
Вот мои настройки:
DATABASES = {
'default': {
'ENGINE': 'django.db.backends.postgresql_psycopg2',
'NAME': 'project',
'HOST': 'localhost',
'PORT': 5432,
'PASSWORD': 'passwd',
'USER': 'user',
},
"logs": {
"NAME": "djongo",
"ENGINE": "djongo",
'HOST': 'localhost',
'PORT': 27017,
"USER": "user",
"PASSWORD": "passwd",
},
}
Я также написал маршрутизатор
class LogsRouter:
route_app_labels = {"logging_system"}
def db_for_read(self, model, **hints):
"""
Attempts to read auth and contenttypes models go to auth_db.
"""
if model._meta.app_label in self.route_app_labels:
return "logs"
return None
def db_for_write(self, model, **hints):
"""
Attempts to write auth and contenttypes models go to auth_db.
"""
if model._meta.app_label in self.route_app_labels:
return "logs"
return None
def allow_relation(self, obj1, obj2, **hints):
"""
Allow relations if a model in the auth or contenttypes apps is
involved.
"""
if (
obj1._meta.app_label in self.route_app_labels
or obj2._meta.app_label in self.route_app_labels
):
return True
return None
def allow_migrate(self, db, app_label, model_name=None, **hints):
"""
Make sure the auth and contenttypes apps only appear in the
'auth_db' database.
"""
if app_label in self.route_app_labels:
return db == "logs"
return None
В тесте я добавил две базы данных:
class TestTestCase(TransactionTestCase):
databases = ["default", "logs"]
При запуске я получаю ошибку:
djongo.exceptions.SQLDecodeError:
Keyword: None
Sub SQL: None
FAILED SQL: ('UPDATE "django_celery_results_taskresult" SET "date_created" = "django_celery_results_taskresult"."date_done"',)
Params: ((),)
Version: 1.3.6
Но почему миграция "django_celery_results_taskresult" пытается применить к MongoDB, ведь я написал в роутере, что только модели из приложения logging_system должны работать с MongoDB?
Что я делаю не так?