如何确定为什么测试中的补丁请求不成功



在测试中我有一个patch request。但是,它不能保存。我知道这一点,因为在patch request之后,我测试了新值是否存在。

如何辨别为什么测试中的patch request失败?

补丁请求:

fullname = "MyName"
phone = "MyPhone"
patch member_path(@user), member: { phone: phone,
                                   fullname: fullname,
                                   password: "",
                                   password_confirmation: "" }
puts @response.message
puts @response.status
assert flash[:success]
assert_redirected_to @user
@user.reload
assert_equal @user.fullname, fullname
Etc.

我已经看了test.log,但从那里我看不到为什么补丁请求不能保存新值。

test.log:

Started PATCH "/members/980190962" for 127.0.0.1 at 2015-05-01 21:26:59 +0000
Processing by MembersController#update as HTML
  Parameters: {"member"=>{"phone"=>"MyPhone", "fullname"=>"MyName", "password"=>"[FILTERED]", "password_confirmation"=>"[FILTERED]"}, "id"=>"980190962"}
...
  [1m[35m (0.1ms)[0m  SAVEPOINT active_record_1
  [1m[36mMember Exists (0.2ms)[0m  [1mSELECT  1 AS one FROM "members" WHERE (LOWER("members"."email") = LOWER('orgone@example.com') AND "members"."id" != 980190962) LIMIT 1[0m
  [1m[35mMember Exists (0.2ms)[0m  SELECT  1 AS one FROM "members" WHERE (LOWER("members"."username") = LOWER('myst1') AND "members"."id" != 980190962) LIMIT 1
  [1m[36m (0.1ms)[0m  [1mROLLBACK TO SAVEPOINT active_record_1[0m
  Rendered shared/_error_messages.html.erb (1.7ms)
...

另外,我还将@response.status@response.message添加到补丁行之后的测试中。但是这些不会产生任何额外的输出,因此我仍然不明白为什么patch request不顺利(它确实可以在开发中起作用)。

控制器中的更新方法:

  def update
    @member = Member.find(params[:id])
    if @member.update_attributes(memberupdate_params)
      flash[:success] = "Profile updated"
      redirect_to @member
    else
      render 'edit'
    end
  end
private
def memberupdate_params
  if ((current_member && current_member.admin?)
    params.require(:member).permit( :email,
                                    :username,
                                    :fullname,
                                    :phone,
                                    :admin,
                                    :password,
                                    :password_confirmation)
  else
    params.require(:member).permit( :email,
                                    :username,
                                    :fullname,
                                    :phone,
                                    :password,
                                    :password_confirmation)
  end
end

您的测试日志SQL在这里看起来错误:

"members"."id" != 980190962

我希望相反:

"members"."id" = 980190962

您是否认为开发环境和测试环境正在使用相同的宝石版本,相同的轨道版本等?

广义,轨道update将包裹在交易中。失败的常见原因是验证错误。请参阅validate!方法以了解如何验证,并查看模型类以查看您是否需要任何特殊验证。

您可能想暂时尝试更改简单的代码,以查看Rails是否会引起例外。

更改此区域:

if @member.update_attributes(memberupdate_params)
  ...

to此爆炸方法:

@member.update_attributes!(memberupdate_params)

最新更新