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

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

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

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

Q&A

解決済

1回答

2369閲覧

railsチュートリアルどおりに行っているがテスト失敗の結果が異なっています。

m0a

総合スコア708

Ruby on Rails 5

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

0グッド

0クリップ

投稿2018/03/29 06:00

以下のURLを参考にrails test でエラーを起こそうとしています。

https://railstutorial.jp/chapters/static_pages?version=5.1#sec-red

期待する実行結果は

$ rails test 3 tests, 2 assertions, 0 failures, 1 errors, 0 skips

ですが、実際は以下のように表示されてしまいます

❯ rails test [12:22:22] Running via Spring preloader in process 7899 Run options: --seed 29526 # Running: Run options: --seed 29526 # Running: ....EE Error: StaticPagesControllerTest#test_should_get_about: ActionView::Template::Error: undefined method `provide2' for #<#<Class:0x00007f8431a98938>:0x00007f8431ecbb68> Did you mean? provide app/views/static_pages/about.html.erb:1:in `_app_views_static_pages_about_html_erb___2785863303060387990_70102882893900' test/controllers/static_pages_controller_test.rb:22:in `block in <class:StaticPagesControllerTest>' Traceback (most recent call last): 27: from -e:1:in `<main>' 26: from /usr/local/Cellar/ruby/2.5.0_2/lib/ruby/2.5.0/rubygems/core_ext/kernel_require.rb:59:in `require' 25: from /usr/local/Cellar/ruby/2.5.0_2/lib/ruby/2.5.0/rubygems/core_ext/kernel_require.rb:59:in `require' 24: from /usr/local/lib/ruby/gems/2.5.0/gems/spring-2.0.2/lib/spring/application/boot.rb:19:in `<top (required)>' 23: from /usr/local/lib/ruby/gems/2.5.0/gems/spring-2.0.2/lib/spring/application.rb:135:in `run' 22: from /usr/local/lib/ruby/gems/2.5.0/gems/spring-2.0.2/lib/spring/application.rb:135:in `loop' 21: from /usr/local/lib/ruby/gems/2.5.0/gems/spring-2.0.2/lib/spring/application.rb:141:in `block in run' 20: from /usr/local/lib/ruby/gems/2.5.0/gems/spring-2.0.2/lib/spring/application.rb:171:in `serve' 19: from /usr/local/lib/ruby/gems/2.5.0/gems/spring-2.0.2/lib/spring/application.rb:171:in `fork' 18: from /usr/local/lib/ruby/gems/2.5.0/gems/minitest-5.11.3/lib/minitest.rb:63:in `block in autorun' 17: from /usr/local/lib/ruby/gems/2.5.0/gems/minitest-5.11.3/lib/minitest.rb:136:in `run' 16: from /usr/local/lib/ruby/gems/2.5.0/gems/minitest-5.11.3/lib/minitest.rb:159:in `__run' 15: from /usr/local/lib/ruby/gems/2.5.0/gems/minitest-5.11.3/lib/minitest.rb:159:in `map' 14: from /usr/local/lib/ruby/gems/2.5.0/gems/minitest-5.11.3/lib/minitest.rb:159:in `block in __run' 13: from /usr/local/lib/ruby/gems/2.5.0/gems/railties-5.1.4/lib/rails/test_unit/line_filtering.rb:9:in `run' 12: from /usr/local/lib/ruby/gems/2.5.0/gems/minitest-5.11.3/lib/minitest.rb:319:in `run' 11: from /usr/local/lib/ruby/gems/2.5.0/gems/minitest-5.11.3/lib/minitest.rb:347:in `with_info_handler' 10: from /usr/local/lib/ruby/gems/2.5.0/gems/minitest-5.11.3/lib/minitest.rb:360:in `on_signal' 9: from /usr/local/lib/ruby/gems/2.5.0/gems/minitest-5.11.3/lib/minitest.rb:320:in `block in run' 8: from /usr/local/lib/ruby/gems/2.5.0/gems/minitest-5.11.3/lib/minitest.rb:320:in `each' 7: from /usr/local/lib/ruby/gems/2.5.0/gems/minitest-5.11.3/lib/minitest.rb:321:in `block (2 levels) in run' 6: from /usr/local/lib/ruby/gems/2.5.0/gems/minitest-5.11.3/lib/minitest.rb:334:in `run_one_method' 5: from /usr/local/lib/ruby/gems/2.5.0/gems/minitest-5.11.3/lib/minitest.rb:802:in `record' 4: from /usr/local/lib/ruby/gems/2.5.0/gems/minitest-5.11.3/lib/minitest.rb:802:in `each' 3: from /usr/local/lib/ruby/gems/2.5.0/gems/minitest-5.11.3/lib/minitest.rb:803:in `block in record' 2: from /usr/local/lib/ruby/gems/2.5.0/gems/railties-5.1.4/lib/rails/test_unit/reporter.rb:23:in `record' 1: from /usr/local/lib/ruby/gems/2.5.0/gems/railties-5.1.4/lib/rails/test_unit/reporter.rb:70:in `format_rerun_snippet' /usr/local/lib/ruby/gems/2.5.0/gems/railties-5.1.4/lib/rails/test_unit/reporter.rb:70:in `method': undefined method `test_should_get_about' for class `Minitest::Result' (NameError)

失敗したテストが知りたいので上記の様な表示は後々困るような予感がします。
どうすればチュートリアルのようにTestの実行結果が出るようにできるでしょうか?

なお開発環境はmac上で作っておりawsのcloud9はつかっていません。

❯ ruby --version ruby 2.5.0p0 (2017-12-25 revision 61468) [x86_64-darwin15] ❯ gem -v 2.7.6

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

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

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

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

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

guest

回答1

0

ベストアンサー

チュートリアルの「3.3.2 Red」は,まだ About ページが全く実装されていない段階での rake test の結果が書かれています。

しかるに,m0a さんのエラーを見ると,
app/views/static_pages/about.html.erb
において存在しない provide2 メソッドを使用している,という内容であり,アクションのメソッドもビューのテンプレートも既に存在しているようです。

つまり,ぜんぜん段階が違うわけですね。
なので同じエラー表示にならないはずです。

なお,m0a の Rails アプリで出たエラーの原因については,コントローラーやテンプレートを示していただかないと分かりません。

投稿2018/03/29 13:48

scivola

総合スコア2108

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

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

m0a

2018/03/29 15:41

申し訳ございません。説明不足でした。provide を provide2にしたのは意図的で無理やりエラーを発生させるためでした。 チュートリアルによると ``3 tests, 2 assertions, 0 failures, 1 errors, 0 skips`` というようにテストでエラーになった回数の情報が出るとのことでしたが、そもそも上記メッセージが表示されずスタックトレースのみの表示となっています。 その点を解決したく質問させていただいておりました。
scivola

2018/03/30 03:30 編集

Traceback の直前までは正常です。 ふつうならここで,例外が発生したテストコードの箇所を表示して次のテストに移るはずですが,その前に落ちていますね。 やっと思い出しました。これ,バグです。 https://github.com/seattlerb/minitest/issues/730 minitest 5.11.x と railties 5.1.4 以下の組み合わせで起こるようです。 Rails 5.1.5 で対策が施されたようなので,bundle update すれば正常になるでしょう。ちなみに今日 Rails 5.1.6 が出ましたね。 なお,今回の対策は minitest 側でなく Rails 側で行われましたが,Rails プロジェクト以外でも同じ問題が起こります。 というのは,minitest は(gem の依存関係の定義上は)railties に依存していないのですが,railties がイントールされた環境下で動かすと railties を読み込むんです。このときに読み込まれる railties が 5.1.4 以下だと同じ不具合が生じます。
m0a

2018/03/30 08:31

ありがとうございます。チュートリアルではrailsのバージョンを5.1.4で固定しているので悩ましいところです。とりあえずバグのない5.1.5にしてみます。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.48%

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

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

質問する

関連した質問