我将 Flask 和 SQLAlchemy(通过 Flask-SQLAlchemy 扩展)与Factory_Boy一起使用。
我的GearItem
模型有一个外键GearCategory
。Factory_BoySubFactory
通过创建在原始工厂中用作外键的对象的函数来处理这个问题。
这是我的模型定义:
class GearCategory(db.Model):
id = db.Column(db.Integer, primary_key=True)
name = db.Column(db.Text, unique=True, nullable=False)
gear_items = db.relationship('GearItem', backref='category',
lazy='dynamic', order_by='GearItem.name')
class GearItem(db.Model):
id = db.Column(db.Integer, primary_key=True)
name = db.Column(db.Text, nullable=False, index=True)
category_id = db.Column(db.Integer, db.ForeignKey('gear_category.id'), index=True)
这是我的 factory_boyFactory
定义:
class GearCategoryFactory(BaseFactory): # Based on factory.alchemy.SQLAlchemyModelFactory
class Meta:
model = gear_models.GearCategory
name = factory.LazyAttribute(lambda n: faker.word())
class GearItemFactory(BaseFactory):
class Meta:
model = gear_models.GearItem
name = factory.LazyAttribute(lambda n: faker.word())
category_id = factory.SubFactory(GearCategoryFactory)
我可以毫无问题地调用GearItemFactory()
它,它显然会生成一个和一个打算用作外键GearItem
的父级。GearCategory
但是,当我调用 时db.session.flush()
,SQLAlchemy 不会将创建的对象SubFactory
转换为可用作外键的整数。相反,它尝试将对象本身传递给底层数据库驱动程序,然后它抱怨不知道如何处理类型的对象GearCategory
。
我得到的错误是sqlalchemy.exc.ProgrammingError: (db_driver) can't adapt type 'GearCategory' [SQL: 'INSERT INTO gear_item (...
我究竟做错了什么?