🎄teratailクリスマスプレゼントキャンペーン2024🎄』開催中!

\teratail特別グッズやAmazonギフトカード最大2,000円分が当たる!/

詳細はこちら
Ruby on Rails 5

Ruby on Rails 5は、オープンソースのWebアプリケーションフレームワークです。「同じことを繰り返さない」というRailsの基本理念のもと、他のフレームワークより少ないコードで簡単に開発できるよう設計されています。

Q&A

1回答

418閲覧

Railstutorial 8.31のユーザーログアウトテストエラーを解決したい

msmf

総合スコア4

Ruby on Rails 5

Ruby on Rails 5は、オープンソースのWebアプリケーションフレームワークです。「同じことを繰り返さない」というRailsの基本理念のもと、他のフレームワークより少ないコードで簡単に開発できるよう設計されています。

0グッド

1クリップ

投稿2019/09/24 12:58

前提・実現したいこと

Railstutorialの第8章を勉強中なのですが、リスト 8.31のユーザーログアウトのテストを実施中に以下のエラーメッセージが発生しました。このエラーメッセージにあるExpected true to be nil or falseが何を意味しているのか、また解決方法を知りたいです。

発生している問題・エラーメッセージ

FAIL["test_login_with_valid_information_followed_by_logout", UsersLoginTest, 0.5413243269999839] test_login_with_valid_information_followed_by_logout#UsersLoginTest (0.54s) Expected true to be nil or false test/integration/users_login_test.rb:31:in `block in <class:UsersLoginTest>' 22/22: [=======================================================================] 100% Time: 00:00:00, Time: 00:00:00 Finished in 0.66416s 22 tests, 53 assertions, 1 failures, 0 errors, 0 skips

該当のソースコード

リスト 8.31以前のテストはGreenになっているので、ここのソースコードに問題があるのだと思うのですが、内容はまったく8.31と同じ内容にしています。

require 'test_helper' class UsersLoginTest < ActionDispatch::IntegrationTest def setup @user = users(:michael) end test "login with invalid information" do get login_path assert_template 'sessions/new' post login_path, params: { session: { email: "", password: "" } } assert_template 'sessions/new' assert_not flash.empty? get root_path assert flash.empty? end test "login with valid information followed by logout" do get login_path post login_path, params: { session: { email: @user.email, password: 'password' } } assert is_logged_in? assert_redirected_to @user follow_redirect! assert_template 'users/show' assert_select "a[href=?]", login_path, count: 0 assert_select "a[href=?]", logout_path assert_select "a[href=?]", user_path(@user) delete logout_path assert_not is_logged_in? assert_redirected_to root_url follow_redirect! assert_select "a[href=?]", login_path assert_select "a[href=?]", logout_path, count: 0 assert_select "a[href=?]", user_path(@user), count: 0 end end

試したこと

・Railstutorial第8章を最初からやり直した
・エラーメッセージ検索したが解決方法が不明
・Cookiesの保存を取消するため、ブラウザを閉じてみた等

補足情報(FW/ツールのバージョンなど)

Rails 5.1.6
AWS Cloud9を使っていて、Railstutorialでガイドされている設定と同じです。
初めての投稿の為、不足情報等ありましたらご教示ください。

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

winterboum

2019/09/30 21:01

test/integration/users_login_test.rb:31: というのはどの行になりますか?
msmf

2019/10/01 12:01

ご質問ありがとうございます。 assert_not is_logged_in? に該当する部分になります。
guest

回答1

0

テストでだけログアウトの処理が失敗し、developmentモードで起動してログアウトをしてみると、成功はするでしょうか?(末尾の演習にある [Log out] リンクをクリックすると、ログアウトできるかどうか)

テストだけ失敗して、ブラウザからは正しくログアウトできるなら、また別の原因になりますので、以下は読み飛ばしてくださいね。

ブラウザからのログアウトもできていない場合は、なにか抜けがあるのでは、と思います。


テストを実施中は、テストを走らせているターミナル側には、上記のようなテスト結果が出てきます。

一方で、logs/test.log には、RAILS_ENV=test な状態でテスト実行時に各コントローラの実行記録とかが出ます。

テストの delete logout_path のところで、ログアウトのリクエストを送信しているので、以下も確認してみてはどうでしょう。

  1. delete logout_path に伴い、routes.rb に記載の通り delete '/logout', to: 'sessions#destroy' (SessionsControllerのdestroyメソッド) が呼ばれているかどうか

  2. SessionsControllerのdestroyメソッドに、log_out の処理が追記されているか

投稿2019/10/06 01:11

suama

総合スコア1997

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

まだベストアンサーが選ばれていません

会員登録して回答してみよう

アカウントをお持ちの方は

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.36%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問