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

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

ただいまの
回答率

89.69%

【Rails】gem 'better_errors'を削除前後でテスト結果が異なる

受付中

回答 0

投稿 編集

  • 評価
  • クリップ 0
  • VIEW 479
退会済みユーザー

退会済みユーザー

 症状

Rails 5.0.2です。タイトル通りなのですが、
gem 'better_errors'を利用時、テストを行うと、

66/66: [===================================================================================================================================] 100% Time: 00:00:09, Time: 00:00:09

Finished in 10.01715s
66 tests, 237 assertions, 0 failures, 0 errors, 0 skips

しっかりテストが通るのですが、一方でGemfileから

 gem 'better_errors' 


を削除し、

$ bundle install

をします。その後、

$ rails test

を行うと

ERROR["test_フォロー", FollowingTest, 9.163654325999914]
 test_フォロー#FollowingTest (9.16s)
NoMethodError:         NoMethodError: undefined method `user_host_host_url' for #<User::RelationshipsController:0x007f8a7e6612b8>
        Did you mean?  user_host_url
                       user_hosts_url
            app/controllers/user/relationships_controller.rb:9:in `block (2 levels) in create'
            app/controllers/user/relationships_controller.rb:8:in `create'
            test/integration/following_test.rb:24:in `block (2 levels) in <class:FollowingTest>'
            test/integration/following_test.rb:23:in `block in <class:FollowingTest>'

ERROR["test_フォロー解除", FollowingTest, 9.32458399099994]
 test_フォロー解除#FollowingTest (9.32s)
NoMethodError:         NoMethodError: undefined method `user_host_host_url' for #<User::RelationshipsController:0x007f8a7e2646b0>
        Did you mean?  user_host_url
                       user_hosts_url
            app/controllers/user/relationships_controller.rb:19:in `block (2 levels) in destroy'
            app/controllers/user/relationships_controller.rb:18:in `destroy'
            test/integration/following_test.rb:38:in `block (2 levels) in <class:FollowingTest>'
            test/integration/following_test.rb:37:in `block in <class:FollowingTest>'

ERROR["test_フォロー(Ajax)", FollowingTest, 9.491528167999945]
 test_フォロー(Ajax)#FollowingTest (9.49s)
ActionView::Template::Error:         ActionView::Template::Error: undefined method `followers' for nil:NilClass
            app/views/user/relationships/create.js.erb:3:in `_app_views_user_relationships_create_js_erb___2393907348688590802_70116398321340'
            test/integration/following_test.rb:30:in `block (2 levels) in <class:FollowingTest>'
            test/integration/following_test.rb:29:in `block in <class:FollowingTest>'

  66/66: [===================================================================================================================================] 100% Time: 00:00:09, Time: 00:00:09

Finished in 9.80524s
66 tests, 234 assertions, 0 failures, 3 errors, 0 skips

このようにエラーが出ます。

今後ゆっくりテストがパスするよう頑張るつもりですが、
どうして、better_errors削除前後でテスト結果が変わるのかがさっぱりです。

個別エラーの意味というより、better_errors削除前後でのテスト仕様(?) について
もし情報をお持ちの方、ご助言頂けるとと幸いです。宜しくお願いします。

 テストのファイル内容

念のため、記載します。

require 'test_helper'

class FollowingTest < ActionDispatch::IntegrationTest

    def setup
      @user = users(:michael)
        @host = hosts(:google)
        log_in_as(@user)
    end

    test "フォローリストページ" do
      get following_user_mypage_path
        assert_not   @user.following.empty?
        assert_match @user.following.count.to_s,response.body
        @user.following.each do |host|
            assert_select "a[href=?]",user_host_path(host)
        end
    end

    test "フォロー" do
      assert_difference '@user.following.count',1 do   
            post user_relationships_path, params: { followed_id: @host.id }
      end
    end

    test "フォロー(Ajax)" do
      assert_difference '@user.following.count',1 do
          post user_relationships_path, params: { followed_id: @host.id }, xhr: true
      end
    end

    test "フォロー解除" do
        @user.follow(@host)
        relationship = @user.active_relationships.find_by(followed_id: @host.id)
        assert_difference '@user.following.count', -1 do
            delete user_relationship_path(relationship)
        end
    end

    test "フォロー解除(Ajax)" do
      @user.follow(@host)
        relationship = @user.active_relationships.find_by(followed_id: @host.id)
        assert_difference '@user.following.count', -1 do
            delete user_relationship_path(relationship),xhr:true
        end
    end

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

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

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

    クリップを取り消します

  • 良い質問の評価を上げる

    以下のような質問は評価を上げましょう

    • 質問内容が明確
    • 自分も答えを知りたい
    • 質問者以外のユーザにも役立つ

    評価が高い質問は、TOPページの「注目」タブのフィードに表示されやすくなります。

    質問の評価を上げたことを取り消します

  • 評価を下げられる数の上限に達しました

    評価を下げることができません

    • 1日5回まで評価を下げられます
    • 1日に1ユーザに対して2回まで評価を下げられます

    質問の評価を下げる

    teratailでは下記のような質問を「具体的に困っていることがない質問」、「サイトポリシーに違反する質問」と定義し、推奨していません。

    • プログラミングに関係のない質問
    • やってほしいことだけを記載した丸投げの質問
    • 問題・課題が含まれていない質問
    • 意図的に内容が抹消された質問
    • 広告と受け取られるような投稿

    評価が下がると、TOPページの「アクティブ」「注目」タブのフィードに表示されにくくなります。

    質問の評価を下げたことを取り消します

    この機能は開放されていません

    評価を下げる条件を満たしてません

    評価を下げる理由を選択してください

    詳細な説明はこちら

    上記に当てはまらず、質問内容が明確になっていない質問には「情報の追加・修正依頼」機能からコメントをしてください。

    質問の評価を下げる機能の利用条件

    この機能を利用するためには、以下の事項を行う必要があります。

まだ回答がついていません

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

  • ただいまの回答率 89.69%
  • 質問をまとめることで、思考を整理して素早く解決
  • テンプレート機能で、簡単に質問をまとめられる