私はDjango
プロジェクトを持っています。このプロジェクトには2つのデータベースがあり、Router
と書いてそのうちの1つをreadonly
とします。私はこのreadonly
データベースを使用するいくつかのユニットテストを書いたが、私はpython manage.py test
を実行すると、それはここでテーブルが読み込み専用テーブル(Django)のテストに存在しません
ProgrammingError: (1146, "Table 'test_arzesh-db.company' doesn't exist")
は、データベースの設定があると言う:
DATABASES = {
'default': {
'ENGINE': 'django.db.backends.mysql',
'NAME': 'broker-website',
'USER': 'root',
'PASSWORD': '',
'HOST': 'localhost',
'OPTIONS': {
"init_command": "SET foreign_key_checks = 0;",
},
},
'arzesh-db': {
'ENGINE': 'django.db.backends.mysql',
'NAME': 'arzesh-db',
'USER': 'root',
'PASSWORD': '',
'TEST_DATABASE': 'default',
},
'TEST': {
'CHARSET': 'utf8',
'COALATION': 'utf8-unicode-ci',
}
}
そしてここでは、私のルータのコードです:ここで
class Router(object):
"""
A router to control all database operations on models in the
auth application.
"""
def db_for_read(self, model, **hints):
"""
Attempts to read auth models go to auth_db.
"""
if model._meta.app_label == 'arzesh':
return 'arzesh-db'
return 'default'
def db_for_write(self, model, **hints):
"""
Attempts to write auth models go to auth_db.
"""
if model._meta.app_label == 'arzesh':
return 'arzesh-db'
return 'default'
def allow_relation(self, obj1, obj2, **hints):
"""
Allow relations if a model in the auth app is involved.
"""
return True
def allow_migrate(self, db, app_label, model=None, **hints):
"""
Make sure the auth app only appears in the 'auth_db'
database.
"""
if app_label == 'arzesh':
return False
return True
は読み取り専用のデータベースにあるモデルです:
class Company(models.Model):
def __unicode__(self):
return self.tick
id = models.AutoField(primary_key=True)
tick = models.CharField(unique=True, max_length=32)
name = models.CharField(max_length=128, unique=True)
class Meta:
managed = False
db_table = 'company'
、ここでユニットテストでエラーを取得するラインである:すべての
company.objects.create(id=1, tick='a', name='a')
@ e4c5投稿を編集して情報を追加しました。ありがとう。 – Navid777