1

2つのデータベースを使用しているWebサイトがあります。djangoのドキュメントに記載されているようにルーターを設定しています。runserverを使用すると、ルーティングは正常に機能します。ただし、LiveServerTestCaseを使用してテストすることはできませんでした。クエリセットは空です。フィクスチャが2番目のデータベースに正しくロードされていないと思います。データベースルーターを削除すると、テストは機能します(したがって、1つのデータベースのみを使用します)。

これが私のルーター設定です:

class ScreenerRouter(object):
    def db_for_read(self, model, **hints):
        if model._meta.app_label == 'screener':
            return 'filemaker'
        return None

    def db_for_write(self, model, **hints):
        if model._meta.app_label == 'screener':
            return 'filemaker'
        return None

    def allow_relation(self, obj1, obj2, **hints):
        if obj1._meta.app_label == 'screener' or obj2._meta.app_label == 'screener':
            return True
        return None

    def allow_syncdb(self, db, model):
        if db == 'filemaker':
            return model._meta.app_label == 'screener'
        elif model._meta.app_label == 'screener':
            return False
        return None

TestCaseでmulti_db=Trueを設定しました。

もう1つの問題は、DBにエントリがある場合でも、dumpdata --database =filemakerscreener.ScreenerRouterが空の配列を返すことでした。DjangoAdminで編集することもできます。データをデフォルトのDBにコピーして、そこからダンプする必要がありました。

4

1 に答える 1

0

私は問題を理解しました。「filemaker」データベースへのアクセスが必要な複数のアプリがあり、それぞれに独自のルーターがありました。ルーターは順番に処理されました。しかし、最初のルーターの allow_syncdb メソッドは、他のすべてのアプリの syncdb と dumpdata を妨げる値を既に返しました。

解決策は、filemaker db 用に 1 つの MasterRouter を作成し、そこにすべてのアプリを配置することでした。次のように:

if obj1._meta.app_label in ['app1', 'app2']:
    return 'filemaker'
于 2012-06-06T18:35:12.387 に答える