Ruby on rails 3 在rspec中测试模型值数组的正确方法是什么?
我还没有弄清楚rspec编写测试的方法,但是如果能帮助我理解我在这个测试中犯了什么错误,我将不胜感激Ruby on rails 3 在rspec中测试模型值数组的正确方法是什么?,ruby-on-rails-3,activerecord,rspec2,Ruby On Rails 3,Activerecord,Rspec2,我还没有弄清楚rspec编写测试的方法,但是如果能帮助我理解我在这个测试中犯了什么错误,我将不胜感激 describe Source do describe "Upcase name" do names = {'bob' => 'Bob', 'edward jones' => 'Edward Jones' 'Edward jones' => 'Edward Jones'} names.each do |name
describe Source do
describe "Upcase name" do
names = {'bob' => 'Bob',
'edward jones' => 'Edward Jones'
'Edward jones' => 'Edward Jones'}
names.each do |name,expect|
before { @source = Source.create(name: name) }
after { @source.destroy! }
it "source #{name} should be #{expect}" do
subject { @source }
@source.name.should == expect
let!(:find) do
Source.find_by_proper_name(expect)
end
it "should find" do
should == find
end
end
end
end
end
我对源模型的name列有一个唯一的约束
测试的每一次迭代都会由于唯一的冲突而作为失败返回。(尽管我认为每次迭代只会创建一个模型
如果我去掉三个中间的一个,那么如果一次创建所有名称,那么所有名称都是唯一的,那么测试就会失败,因为@source等于所有测试中的最后一个值
基本上,我想要一种干燥的方式来编写测试
Source.create(name: "bob").name.should == "Bob"
Source.create(name: "edward jones").name.should == "Edward Jones"
Source.create(name: "Edward jones").name.should == "Edward Jones"
我该怎么做呢?你在里面混了很多东西 第一件事:
- 不要嵌套
it
- 不要在
中使用it
,它们属于let
上下文
- 不要迭代
s在it
s中迭代it
- 不要自己清理数据库,使用数据库清理器或事务性装置或类似的东西