我正在试着优化一下我的规格。我通常在为嵌套资源和用户创建测试数据时遇到问题。我通常会用一个before(:each)来设置数据,这是由我的120多个规范运行的。让我向你展示:(这不准确,但你应该明白这一点)
def setup_test_data
@user = FactoryGirl.create(:admin_with_account)
@account = @user.account
3.times do |n|
list = FactoryGirl.create(:list)
list.items << FactoryGirl.create_list(:item, 3)
@account.lists << list
end
end
before(:each){setup_test_data}
subject{List.merge(list1, list2)}
it{should have(6).items}这就是为什么我没能缩短我的测试数据设置
def self.merge(lists)
merged_list = lists.first.account.subscriber_lists.build
name = "Merge of "
lists.each do |list|
name << "'#{list.name}', "
list.items.each do |item|
merged_list.items.build(item.dup.attributes)
end
end
merged_list.name = name.chop.chop
merged_list.save!
merged_list.reload # I use this to filter out duplicates via validations
end我的选择: A)将一些逻辑移回控制器,减少对帐户的依赖,保存在控制器中B)更多地存根/模拟,但使用嵌套资源+关联很难做到
C)你的想法:
谢谢你,雷
发布于 2012-03-19 22:11:03
C)创建您自己的RSpec rake任务,它将首先导入一些基本数据,然后使用DatabaseCleaner确保一切都以事务方式运行(您必须在自定义rake任务之后手动清除DB,因为出于某种原因,它似乎不是这样的,但对于DatabaseCleaner,这是一行程序)。
在我有一个需要测试的大型预定义数据集,并希望只创建一次,然后对其执行事务性测试的情况下,我会使用这种方法。
如果你对此感兴趣,请让我知道,我可以提供更多的代码来帮助你。
https://stackoverflow.com/questions/9771522
复制相似问题