1

3.1 へのアップグレードに取り組んでいますが、問題が発生しました。

どうやらRakeによって「リンク」メソッドが上書きされているモデル(Mongoidを使用)があります。次のメッセージが表示されます。

WARNING: Global access to Rake DSL methods is deprecated.  Please include
...  Rake::DSL into classes and modules which use the Rake DSL methods.
WARNING: DSL method Profile#link called at /Users/jeffdeville/Documents/code/ruby/wg/app/models/profile.rb:62:in `block in eql?'

メソッドが解決されているため、スタックトレースなどはありません。これは私の rspec で発生しますが、コンソールでは問題は発生しません。

Gemfile は以下にあります。

答えがわからない場合でも、ここでデバッグ プロセスにどのようにアプローチするかについて何か提案があれば、それは素晴らしいことです。

-ジェフ

source 'http://rubygems.org'

gem 'rails', "3.1.0"
gem 'rake'
gem 'mail'

gem 'compass', "~> 0.12.alpha.0"
gem 'jquery-rails'
gem 'haml-rails'
gem "html5-boilerplate"

gem 'mini_fb', :git => 'git://github.com/jeffdeville/mini_fb.git'
gem "json"
gem "bson"
gem "bson_ext"
gem 'sucker'
gem 'crack', :git => 'git://github.com/ericgj/crack.git'
gem 'hoptoad_notifier'
gem 'httparty'
gem 'facebooker2'
gem 'delayed_job'
gem 'delayed_job_mongoid'
gem 'unicorn'
gem 'hirefireapp'
gem 'mogli', :git => 'https://github.com/jeffdeville/mogli.git'
gem 'typhoeus'
gem 'koala'
gem 'foreman'
gem 'heroku'
gem 'rbing'
gem 'rmagick'
gem 'mini_magick'
gem 'aws-sdk'
gem 'mechanize'

# Gems used only for assets and not required
# in production environments by default.
group :assets do
  gem 'sass-rails', "  ~> 3.1.0"
  gem 'coffee-rails', "~> 3.1.0"
  gem 'uglifier'
end

group :development, :test do
  gem 'awesome_print'
  gem 'pry'
end

group :development do
  gem 'rails3-generators'
    gem 'coffee-script'
    gem 'guard'
    gem 'guard-coffeescript'
    gem 'guard-livereload'
  gem 'guard-rspec'
  gem 'guard-spork'
  gem 'guard-bundler'
  gem 'mailcatcher'
  gem 'foreman'
end

group :test do
    gem "factory_girl_rails"
  gem 'fuubar'
  gem 'spork', '~> 0.9.0.rc'
    gem 'ruby-debug19'
    gem "rspec"
  gem "rspec-given"
    gem "rspec-rails"
  gem 'mocha'
  gem "bourne"
    gem 'webmock'
    gem 'vcr'
    gem 'jasmine'
    gem 'email_spec'
  gem 'timecop'
end

group :mac do
#  if RUBY_PLATFORM =~ /darwin/i
    gem 'rb-fsevent'
    gem 'growl'
#  end
end
4

1 に答える 1

1

次のことを行ったときに、同様の問題が発生していました。

api_client = API::Client
api_model = 'task' #this is dynamic in reality...
api_client.send(api_model).list

Rake のグローバル DSLタスクメソッドは、何らかの理由で送信を破壊していましたが、(send を使用せずに) 直接呼び出した場合、呼び出しは機能しました。最後に、動的呼び出しを仔牛に変更しました。

eval "api_client.#{api_model}.list"

遅いですが、最終的に Rake からグローバル DSL が削除されたら元に戻します。

HTH、YMMV ;-)

于 2011-09-22T11:26:29.500 に答える