質問をすることでしか得られない、回答やアドバイスがある。

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

新規登録して質問してみよう
ただいま回答率
85.48%
Cloud9

Cloud9は、クラウドからのプログラミングが可能になるWebサービス。IDEとしての機能が搭載されており、GitHubやHerokuなど他ツールとの連携も可能です。ブラウザ上で動くため、デバイスに関係なく開発環境を準備できます。

Cookie

HTTPにおけるCookieとは、クライアントのウェブブラウザ上に保存された一時的なデータを指します。クライアント側のJavaScriptでも、サーバー側のHTTPヘッダーでもクッキーの読み書き・修正・削除が可能です。

Ruby on Rails

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

テスト駆動開発

テスト駆動開発は、 プログラム開発手法の一種で、 プログラムに必要な各機能をテストとして書き、 そのテストが動作する必要最低限な実装を行い コードを洗練させる、といったサイクルを繰り返す手法の事です。

Q&A

解決済

1回答

694閲覧

Ruby on Rails チュートリアル第9章

yuukimame

総合スコア11

Cloud9

Cloud9は、クラウドからのプログラミングが可能になるWebサービス。IDEとしての機能が搭載されており、GitHubやHerokuなど他ツールとの連携も可能です。ブラウザ上で動くため、デバイスに関係なく開発環境を準備できます。

Cookie

HTTPにおけるCookieとは、クライアントのウェブブラウザ上に保存された一時的なデータを指します。クライアント側のJavaScriptでも、サーバー側のHTTPヘッダーでもクッキーの読み書き・修正・削除が可能です。

Ruby on Rails

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

テスト駆動開発

テスト駆動開発は、 プログラム開発手法の一種で、 プログラムに必要な各機能をテストとして書き、 そのテストが動作する必要最低限な実装を行い コードを洗練させる、といったサイクルを繰り返す手法の事です。

0グッド

0クリップ

投稿2020/02/14 11:37

前提・実現したいこと

Ruby on Rails チュートリアルの第9章を進めています。
『9.3.1 [Remember me] ボックスをテストする』演習で、エラーが発生しました。
どうにかエラーを解決したいのですが、エラー文の意味が分からず、困っています。

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

FAIL["test_login_with_remembering", UsersLoginTest, 0.6064859070011153]
test_login_with_remembering#UsersLoginTest (0.61s)
--- expected
+++ actual
@@ -1 +1,2 @@
-"InI2WGVlWWFKV1FqQklWSGtyQmtUT3ci--682221f00216ded6f16e0eee27c8b63ea5501d07"
+# encoding: US-ASCII
+"r6XeeYaJWQjBIVHkrBkTOw"
test/integration/users_login_test.rb:42:in `block in class:UsersLoginTest'

該当のソースコード

test/integration/users_login_test.rb

test "login with remembering" do
log_in_as(@user, remember_me: '1')
assert_equal cookies['remember_token'], assigns(:user).remember_token
end

test "login without remembering" do
log_in_as(@user, remember_me: '1')
delete logout_path
log_in_as(@user, remember_me: '0')
assert_empty cookies['remember_token']
end
end

試したこと

エラーの意味を解読するべく検索したのですが、エラーの意味が分かりません。
どこを、どのように修正すればいいのかも見当がつきません。

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

AWSのCloud9で書いてます。

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

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

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

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

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

guest

回答1

0

ベストアンサー

terminal

1FAIL["test_login_with_remembering", UsersLoginTest, 0.6064859070011153] 2test_login_with_remembering#UsersLoginTest (0.61s)

"login_with_remembering"という名前のテストが失敗しています。

terminal

1--- expected 2+++ actual 3@@ -1 +1,2 @@ 4-"InI2WGVlWWFKV1FqQklWSGtyQmtUT3ci--682221f00216ded6f16e0eee27c8b63ea5501d07" 5+# encoding: US-ASCII 6+"r6XeeYaJWQjBIVHkrBkTOw"

-の部分が期待されている(こうなるはずと予想される)出力で、+の部分が実際に出力されている内容です。

terminal

1test/integration/users_login_test.rb:42:in `block in <class:UsersLoginTest>'

エラーが起こっている場所(バックトレースといいます)です。
test/integration/users_login_test.rbの42行目を見てください。

rb:test/integration/users_login_test.rb

1assert_equal cookies['remember_token'], assigns(:user).remember_token

の部分だと思います。

assert_equal a, b は「bがaと等しいはず」という意味なので、
assigns(:user).remember_token"InI2WGVlWWFKV1FqQklWSGtyQmtUT3ci--682221f00216ded6f16e0eee27c8b63ea5501d07"cookies['remember_token'])になるはずなのに、実際は"r6XeeYaJWQjBIVHkrBkTOw"になっている。
という意味です。

しかし、remember_tokenはbase64になるように設定しているはずなので、cookies['remember_token']の方が間違っていると思います。
cookies['remember_token']remember_digestの値が入っているような気がするので、app/models/user.rbapp/helpers/sessions_helper.rbで書き間違いをしていないか確認してみてください。

投稿2020/02/16 16:45

aiandrox

総合スコア52

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

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

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.48%

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

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

質問する

関連した質問