少し頭を悩ませましたが、すべてを間違って渡していることがわかりました。私が思いついた解決策は間違いなく最善の解決策ではなく、おそらく書き直される可能性がありますが、機能し、今のところそれで十分です。
rspec スニペットへの変更は、シンボル :newpoints で表されるハッシュを作成することでした
it "should find Points and return object" do
put :update, :username => "tester", :newpoints => {"experience_points" => 10, "shame_points" => 15, "gold" => 0}, :format => :xml
end
コントローラーでのこのリクエストの処理には少し調整が必要でしたが、関連する部分は次のとおりです。
class PointsController < ApplicationController
#before_filter :authenticate, :only => :update
before_filter :must_specify_user
before_filter :fix_params
before_filter :clean_up
respond_to :html, :xml, :json
def fix_params
if params[:points]
params[:points][:user_id] = @user.id if @user
end
end
def clean_up
@newpoints = params[:newpoints]
@experience = @newpoints["experience_points"]
@shame = @newpoints["shame_points"]
@gold = @newpoints["gold"]
@xp = @experience.to_i
@sp = @shame.to_i
@cash = @gold.to_i
end
def update
points = Points.find_by_user_id(@user.id, params[:id])
xp = points.experience_points
sp = points.shame_points
cash = points.gold
final_experience = xp += @xp
final_shame = sp += @sp
final_gold = cash += @cash
final_points = {:experience_points => final_experience, :shame_points => final_shame, :gold => final_gold}
if_found points do
respond_to do |format|
if points.update_attributes!(params[final_points])
format.json { head :ok }
format.xml { head :ok }
else
format.json { render :nothing => true, :status => "401 Not Authorized"}
format.xml { render :nothing => true, :status => "401 Not Authorized"}
end
end
end
end
end
明らかに、これを DRY に準拠させるためにできることはたくさんあるので、どんな提案も大歓迎です。前もって感謝します!