在测试中我有一个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)