При использовании двух баз данных в тестах 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?

Что я делаю не так?

Вернуться на верх