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

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

ただいまの
回答率

90.51%

  • Ruby on Rails 4

    2544questions

    Ruby on Rails4はRubyによって書かれたオープンソースのウェブフレームワークです。 Ruby on Railsは「設定より規約」の原則に従っており、効率的に作業を行うために再開発を行う必要をなくしてくれます。

test-unit-rails を Gemfile に記述すると rake db:migrate RAILS_ENV=test に失敗する

解決済

回答 1

投稿

  • 評価
  • クリップ 0
  • VIEW 698

ltcmdr927

score 6

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

Rails4 アプリケーションにおいて test-unit および test-unit-rails を使ったユニットテストを記述しようとしていますが、Gemfile において

group :test do
  gem 'test-unit-rails'
end

のように test-unit-rails を記述すると、rake db:migrate RAILS_ENV=test を実行した際、 rake aborted となり失敗します。

$ rake db:migrate RAILS_ENV=test
rake aborted!
NameError: uninitialized constant ActiveSupport::Testing::ConstantLookup
/path/to/rails-project-dir/config/environment.rb:5:in `<top (required)>'
Tasks: TOP => db:migrate:reset => db:migrate => environment
(See full trace by running task with --trace)

同様の現象は rake db:create RAILS_ENV=test や rake db:migrate:reset RAILS_ENV=test など、 RAILS_ENV に test がセットされた場合のデータベースに関係する rake task において現出するようです。

その場合、 Gemfile から test-unit-rails をコメントアウトすれば問題なく実行できます。

また test-unit-rails が記述されていても rake test によるテストは問題なく実施できます。

$ bundle exec rake test
Loaded suite /path/to/users-home/.rbenv/versions/2.2.3/bin/rake
Started
..

Finished in 0.032617 seconds.
----------------------------------------------------------------------------------------------------------------------------------------
2 tests, 4 assertions, 0 failures, 0 errors, 0 pendings, 0 omissions, 0 notifications
100% passed
----------------------------------------------------------------------------------------------------------------------------------------
61.32 tests/s, 122.64 assertions/s

実現したいこと

Gemfile に test-unit-rails が指定されている状態でも、rake db:migrate RAILS_ENV=test などの rake task が実行できるようにしたい。

該当のソースコード

Gemfile (抜粋)

ruby '2.2.3'
# ...
gem 'rails', '4.2.4'
gem 'mysql2', '~> 0.3.13'
# ...
group :test do
  gem 'test-unit'
  gem 'test-unit-rails', '~> 1.0.4'
end

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

Mac OS X El Capitan (10.11.6)
Ruby 2.2.3p173
rails 4.2.4
test-unit 3.2.3
test-unit-rails 1.0.4

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

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

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

    クリップを取り消します

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

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

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

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

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

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

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

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

    質問の評価を下げる

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

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

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

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

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

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

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

    詳細な説明はこちら

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

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

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

回答 1

check解決した方法

0

自己解決しました。

$ vi Gemfile
# mysql2 と test-unit-rails のバージョン指定を消す
...
gem 'mysql2'
...
group :test do
    gem 'test-unit-rails'
end
...
$ bundle update
# 最新版の mysql2 と test-unit-rails がインストールされる
...
Installing mysql2 0.4.5 (was 0.3.21) with native extensions
...
Using test-unit-rails 5.0.2 (was 1.0.4)
...
$ vi Gemfile
# mysql2 のバージョンだけを元に戻す(test-unit-railsはそのまま)
...
gem 'mysql2', '~> 0.3.13'
...
$ bundle install
$ bundle exec rake test
# rake test に成功
Loaded suite /path/to/.rbenv/versions/2.2.3/bin/rake
Started
..

Finished in 0.032864 seconds.
--------------------------------------------------------------------------------------------------------------------------------------------------------
2 tests, 4 assertions, 0 failures, 0 errors, 0 pendings, 0 omissions, 0 notifications
100% passed
--------------------------------------------------------------------------------------------------------------------------------------------------------
60.86 tests/s, 121.71 assertions/s
$ bundle exec rake db:migrate:reset RAILS_ENV=test
# rake db:migrate:reset RAILS_ENV=test も成功
== 20160120015233 CreateHoge: migrating =======================================
-- create_table(:hoges)
   -> 0.0103s
-- add_index(:hoges, [:text1, :text2])
   -> 0.0080s
== 20160120015233 CreateHoge: migrated (0.0184s) =============================
...

恐らくですが test-unit-rails のバージョン指定が古すぎたのと、
mysql2 がうまくインストールされていなかったのが原因のようでした。

投稿

  • 回答の評価を上げる

    以下のような回答は評価を上げましょう

    • 正しい回答
    • わかりやすい回答
    • ためになる回答

    評価が高い回答ほどページの上位に表示されます。

  • 回答の評価を下げる

    下記のような回答は推奨されていません。

    • 間違っている回答
    • 質問の回答になっていない投稿
    • スパムや攻撃的な表現を用いた投稿

    評価を下げる際はその理由を明確に伝え、適切な回答に修正してもらいましょう。

同じタグがついた質問を見る

  • Ruby on Rails 4

    2544questions

    Ruby on Rails4はRubyによって書かれたオープンソースのウェブフレームワークです。 Ruby on Railsは「設定より規約」の原則に従っており、効率的に作業を行うために再開発を行う必要をなくしてくれます。