前提・実現したいこと
Rails チュートリアル10章のログインしたユーザーだけが情報を編集できるようにセキュリティを実装する部分(10.2.2)の部分でつまづいてしまいました
タイプミスなどの可能性も考慮してコードをコピペしてみたのですが解決できませんでした
コードは下記の通りです
test/fixtures/users.yml michael: name: Michael Example email: michael@example.com password_digest: <%= User.digest('password') %> archer: name: Sterling Archer email: duchess@example.gov password_digest: <%= User.digest('password') %>
test/controllers/users_controller_test.rb require 'test_helper' class UsersControllerTest < ActionDispatch::IntegrationTest def setup @user = users(:michael) @other_user = users(:archer) end test "should get new" do get signup_path assert_response :success end test "should redirect edit when not logged in" do get edit_user_path(@user) assert_not flash.empty? assert_redirected_to login_url end test "should redirect update when not logged in" do patch user_path(@user), params: { user: { name: @user.name, email: @user.email } } assert_not flash.empty? assert_redirected_to login_url end test "should redirect edit when logged in as wrong user" do log_in_as(@other_user) get edit_user_path(@user) assert flash.empty? assert_redirected_to root_url end test "should redirect update when logged in as wrong user" do log_in_as(@other_user) patch user_path(@user), params: { user: { name: @user.name, email: @user.email } } assert flash.empty? assert_redirected_to root_url end end
app/controllers/users_controller.rb class UsersController < ApplicationController before_action :logged_in_user, only: [:edit, :update] before_action :correct_user, only: [:edit, :update] # GET /users/:id def show @user = User.find(params[:id]) # => app/views/users/show.html.erb # debugger end def new @user = User.new # => form_for @user end # POST /users def create @user = User.new(user_params) if @user.save log_in @user flash[:success] = "Welcome to the Sample App!" redirect_to @user else render 'new' end end def edit end def update if @user.update_attributes(user_params) flash[:success] = "Profile updated" redirect_to @user else render 'edit' end end private def user_params params.require(:user).permit(:name, :email, :password, :password_confirmation) end # beforeアクション # ログイン済みユーザーかどうか確認 def logged_in_user unless logged_in? flash[:danger] = "Please log in." redirect_to login_url end end # 正しいユーザーかどうか確認 def correct_user @user = User.find(params[:id]) redirect_to(root_url) unless @user == current_user end end
下記のエラーメッセージと同じものが32個出てきました
エラーメッセージ(ターミナル) UsersControllerTest#test_should_redirect_edit_when_logged_in_as_wrong_user: ActiveRecord::Fixture::FixtureError: table "users" has no column named "archer". Error: UsersControllerTest#test_should_redirect_edit_when_logged_in_as_wrong_user: NoMethodError: undefined method `each' for nil:NilClass
試したこと
Railsチュートリアルに載っているコードをコピペした(→何も変わらなかった)
コピペということなので、良いとは思いますが...
ymlのソースファイルは正しくインデントされてますよね?
(記載されているymlコードは問題ないようですが...)
以下のようにarcherとカラム名のインデントが揃っていると、そのようなエラーが出ます。
archer:
name: Sterling Archer
email: duchess@example.gov
password_digest: <%= User.digest('password') %>
同じエラーを調べましたが、インデント問題以外は見つかりませんでした...
michaelが問題なくて、archerで引っかかる理由が謎ですね(。-`ω´-)ンー
インデントを揃えたら解決できました
ありがとうございます
あなたの回答
tips
プレビュー