1

我想写控制器测试相关的密码更新测试。我在控制器的第一行找到了经过身份验证的人,条件是。我如何编写与这一行相关的测试。我不能放弃任何想法。

更改密码控制器

def update
  person = Person.where(_id: session[:user_id]).first
  identity = Identity.where(_id: person.user_id).first
  unless params[:new_password] != params[:new_password_confirmation]
    identity.password = params[:new_password].to_s
    identity.password_confirmation = params[:new_password].to_s
    identity.save
    redirect_to root_url, :notice => "Password has been changed." + person.user_id
  else
    redirect_to :back, :alert => "Password & password confirmation are not match" 
  end
end

ChangePasswordsController 测试

describe ChangePasswordsController do

  setup do
    request.env["omniauth.auth"] = OmniAuth.config.mock_auth[:identity] 
    @auth=request.env["omniauth.auth"]
  end

  it "should have edit action" do
    get :edit
    assert_response :success
  end

  it "should find person" do
     ... 
  end

  it "should find identity" do
     ... 
  end

end
4

1 回答 1

0

我不认为你应该写一个测试 where 是否找到一个人。在这种情况下,您最好只检查 update 方法是否使用给定参数调用 Person 上的 find 方法。使用这样的东西:

Person.should_receive(:find).with(id: <the userid you've setup for the test>) {[Person.new]}

它应该也可以先检查,但我不记得了,与chaintubbing有关。

于 2013-03-29T11:45:51.867 回答