Rolify gemを追加したばかりで、いくつかの rspec テストを実行しています。
2つのテストは次のとおりです。
describe "roles" do
before(:each) do
@user = FactoryGirl.create(:user)
end
it "should not approve incorrect roles" do
@user.add_role :moderator
@user.has_role? :admin
should be_false
end
it "should approve correct roles" do
@user.add_role :moderator
@user.has_role? :moderator
should be_true
end
end
テスト結果は次のとおりです。
1) User roles should not approve incorrect roles
Failure/Error: should be_false
expected: false value
got: #<User id: nil, email: "", encrypted_password: "", reset_password_token: nil, reset_password_sent_at: nil, remember_created_at: nil, sign_in_count: 0, current_sign_in_at: nil, last_sign_in_at: nil, current_sign_in_ip: nil, last_sign_in_ip: nil, confirmation_token: nil, confirmed_at: nil, confirmation_sent_at: nil, name: nil, position: nil, location: nil, admin: false, archived: false, public_email: false, created_at: nil, updated_at: nil>
# ./spec/models/user_spec.rb:70:in `block (3 levels) in <top (required)>'
Finished in 1.37 seconds
7 examples, 1 failure
Failed examples:
rspec ./spec/models/user_spec.rb:67 # User roles should not approve incorrect roles
Randomized with seed 13074
factory.rb
FactoryGirl.define do
factory :user do
sequence(:name) {|n| "Example User #{n}"}
sequence(:email) {|n| "email#{n}@program.com" }
position "Regular"
location "Anywhere, USA"
public_email false
password "foobar"
password_confirmation "foobar"
confirmed_at Time.now
end
end
最初のテストは nil オブジェクトで失敗するのに、2 番目のテストは成功するのはなぜですか?
編集
さらに検査すると、追加されたロールがチェックされたロールと一致するかどうかに関係なく、すべてのテストにshould be_true
合格し、すべてのテストに失敗します。should be_false