运行测试时,FactoryGirl的索引重复输入

时间:2011-08-21 00:33:34

标签: ruby-on-rails ruby-on-rails-3 rspec rspec2 factory-bot

我正在使用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。

1 个答案:

答案 0 :(得分:3)

为您的工厂添加序列:

Factory.sequence :code do |n|
  "AAA#{n}"
end

在您的专业工厂使用序列:

Factory.define :specialty do |f|
  f.code { Factory.next(:code) }
  # other assignments here
end

这样您将始终拥有新代码。