我正在使用 FactoryGirl 创建一个“专业”模型,该模型在 code
上具有唯一索引柱子。
当我创建“专业”模型的多个工厂时,我收到此错误:
Failure/Error: Factory(:specialty)
Mysql::Error: Duplicate entry 'AN00' for key 'index_specialties_on_code': INSERT INTO `specialties` (`code`, `name`) VALUES ('AN00', 'Name')
Duplicate entry 'AN00' for key 'index_specialties_on_code'
处理这个问题的正确方法是什么?为什么与模型关联的索引没有被模型吹走。我正在使用 DatabaseCleaner。
最佳答案
为您的工厂添加一个序列:
Factory.sequence :code do |n|
"AAA#{n}"
end
在您的专业工厂使用以下序列:
Factory.define :specialty do |f|
f.code { Factory.next(:code) }
# other assignments here
end
这样,您将始终拥有新代码。
关于ruby-on-rails - 运行测试时使用 FactoryGirl 重复索引条目,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/7135597/