rspec的一些常见用法
这里讲了如何安装rspec,安装使用rspec。
下面介绍一下rspec中常见的使用方法。
下面是一个最简单的测试用例,判断true是不是等于true,should_be是旧的用法,新用法推荐使用expect()
it "is true when true" do true.should be_true end
#新用法
it "is true when true" do expect(true).to be_true end
一,测试models中的方法
1,测试实例方法
#spec/models/contact_spec.rb
def name
[firstname, lastname].join(' ')
end
#spec/models/contact_spec.rb it "returns a contact's full name as a string" do contact = Contact.new(firstname: 'John', lastname: 'Doe', email: 'johndoe@example.com') expect(contact.name).to eq 'John Doe' end
测试相等时,RSpec 推荐使用 eq 而不是 ==。
2,测试类方法和作用域
#spec/models/contact_spec.rb def self.by_letter(letter) where("lastname LIKE ?", "#{letter}%").order(:lastname) end
require 'spec_helper' describe Contact do # earlier validation examples omitted ... it "returns a sorted array of results that match" do smith = Contact.create(firstname: 'John', lastname: 'Smith', email: 'jsmith@example.com'), jones = Contact.create(firstname: 'Tim', lastname: 'Jones', email: 'tjones@example.com'), johnson = Contact.create(firstname: 'John', lastname: 'Johnson', email: 'jjohnson@example.com') expect(Contact.by_letter("J")).to eq [johnson, jones] end end
使用下面代码来检测返回值中是否没有包含联系人 smith
expect(Contact.by_letter("J")).to_not include smith
3,捕获异常
expect { result = UI::ApplinkSqlBackup.get_sql_server_info(header, input) }.to raise_error(Esfbase::EsfStandardError)
将可能发生异常的代码写在expect中,期待返回Esfbase::EsfStandardError类型的error