Railsのコンソールからコントローラー/ビューメソッドを呼び出すにはどうすればよいですか?

StackOverflow https://stackoverflow.com/questions/151030

  •  02-07-2019
  •  | 
  •  

質問

script / console を読み込むと、時々コントローラーやビューヘルパーメソッドの出力を再生したいことがあります。

次の方法があります:

  • リクエストをシミュレートしますか
  • 上記のリクエストでコントローラーインスタンスからメソッドを呼び出しますか?
  • 上記のコントローラーインスタンスまたは別の方法でヘルパーメソッドをテストしますか?
役に立ちましたか?

解決

ヘルパーを呼び出すには、 helper オブジェクトを使用します:

$ ./script/console
>> helper.number_to_currency('123.45')
=> "R$ 123,45"

デフォルトで含まれていないヘルパーを使用する場合(たとえば、 ApplicationController から helper:all を削除したため)、ヘルパーを含めるだけです。

>> include BogusHelper
>> helper.bogus
=> "bogus output"

コントローラーの処理に関しては、ニックのの答え:

> app.get '/posts/1'
> response = app.response
# you now have a rails response object much like the integration tests

> response.body            # get you the HTML
> response.cookies         # hash of the cookies

# etc, etc

他のヒント

スクリプト/コンソールからコントローラーアクションを呼び出し、応答オブジェクトを表示/操作する簡単な方法は次のとおりです。

> app.get '/posts/1'
> response = app.response
# you now have a rails response object much like the integration tests

> response.body            # get you the HTML
> response.cookies         # hash of the cookies

# etc, etc

アプリオブジェクトは ActionController :: Integration :: Session

これはRails 2.1および2.3を使用して動作します。以前のバージョンは試しませんでした。

コンソールからテストする必要がある場合(Rails 3.1および4.1でテスト済み):

コントローラーアクションの呼び出し:

app.get '/'              
   app.response            
   app.response.headers  # => { "Content-Type"=>"text/html", ... }
   app.response.body     # => "<!DOCTYPE html>\n<html>\n\n<head>\n..." 

ApplicationControllerメソッド:

foo = ActionController::Base::ApplicationController.new
foo.public_methods(true||false).sort
foo.some_method 

ルートヘルパー:

app.myresource_path     # => "/myresource" 
app.myresource_url      # => "http://www.example.com/myresource"

ヘルパーの表示:

foo = ActionView::Base.new

foo.javascript_include_tag 'myscript' #=> "<script src=\"/javascripts/myscript.js\"></script>"

helper.link_to "foo", "bar" #=> "<a href=\"bar\">foo</a>"

ActionController::Base.helpers.image_tag('logo.png')  #=> "<img alt=\"Logo\" src=\"/images/logo.png\" />"

レンダリング:

views = Rails::Application::Configuration.new(Rails.root).paths["app/views"]
views_helper = ActionView::Base.new views
views_helper.render 'myview/mytemplate'
views_helper.render file: 'myview/_mypartial', locals: {my_var: "display:block;"}
views_helper.assets_prefix  #=> '/assets'

ActiveSupportメソッド:

require 'active_support/all'
1.week.ago
=> 2013-08-31 10:07:26 -0300
a = {'a'=>123}
a.symbolize_keys
=> {:a=>123}

Libモジュール:

> require 'my_utils'
 => true 
> include MyUtils
 => Object 
> MyUtils.say "hi"
evaluate: hi
 => true 

コンソールを介してこれを行う1つの方法を次に示します。

>> foo = ActionView::Base.new
=> #<ActionView::Base:0x2aaab0ac2af8 @assigns_added=nil, @assigns={}, @helpers=#<ActionView::Base::ProxyModule:0x2aaab0ac2a58>, @controller=nil, @view_paths=[]>

>> foo.extend YourHelperModule
=> #<ActionView::Base:0x2aaab0ac2af8 @assigns_added=nil, @assigns={}, @helpers=#<ActionView::Base::ProxyModule:0x2aaab0ac2a58>, @controller=nil, @view_paths=[]>

>> foo.your_helper_method(args)
=> "<html>created by your helper</html>"

ActionView :: Base の新しいインスタンスを作成すると、ヘルパーが使用する可能性のある通常のビューメソッドにアクセスできます。次に、 YourHelperModule を拡張すると、そのメソッドがオブジェクトにミックスされ、戻り値を表示できます。

これを行う別の方法は、railsデバッガーを使用することです。デバッグに関するRailsガイドが http://guides.rubyonrails.org/debugging_rails_applications.html にあります。

基本的に、-uオプションを使用してサーバーを起動します。

./script/server -u

次に、コントローラ/ヘルパー/などにアクセスしたいスクリプトにブレークポイントを挿入します。

class EventsController < ApplicationController
  def index
    debugger
  end
end

また、リクエストを行ってコード内のその部分をヒットすると、サーバーコンソールはプロンプトを返し、コマンドプロンプトからリクエストを作成したり、オブジェクトを表示したりすることができます。終了したら、「cont」と入力して実行を続行します。拡張デバッグ用のオプションもありますが、少なくともこれで開始できます。

メソッドが POST メソッドの場合

app.post 'controller/action?parameter1=value1&parameter2=value2'

[ここでのパラメータは適用可能性に応じて変わります]

GET メソッドの場合はelse、

app.get 'controller/action'

精製所を例に、認証済みのPOSTリクエストを作成する方法を次に示します。

# Start Rails console
rails console
# Get the login form
app.get '/community_members/sign_in'
# View the session
app.session.to_hash
# Copy the CSRF token "_csrf_token" and place it in the login request.
# Log in from the console to create a session
app.post '/community_members/login', {"authenticity_token"=>"gT7G17RNFaWUDLC6PJGapwHk/OEyYfI1V8yrlg0lHpM=",  "refinery_user[login]"=>'chloe', 'refinery_user[password]'=>'test'}
# View the session to verify CSRF token is the same
app.session.to_hash
# Copy the CSRF token "_csrf_token" and place it in the request. It's best to edit this in Notepad++
app.post '/refinery/blog/posts', {"authenticity_token"=>"gT7G17RNFaWUDLC6PJGapwHk/OEyYfI1V8yrlg0lHpM=", "switch_locale"=>"en", "post"=>{"title"=>"Test", "homepage"=>"0", "featured"=>"0", "magazine"=>"0", "refinery_category_ids"=>["1282"], "body"=>"Tests do a body good.", "custom_teaser"=>"", "draft"=>"0", "tag_list"=>"", "published_at(1i)"=>"2014", "published_at(2i)"=>"5", "published_at(3i)"=>"27", "published_at(4i)"=>"21", "published_at(5i)"=>"20", "custom_url"=>"", "source_url_title"=>"", "source_url"=>"", "user_id"=>"56", "browser_title"=>"", "meta_description"=>""}, "continue_editing"=>"false", "locale"=>:en}

エラーが発生した場合、これらも役立つ場合があります。

app.cookies.to_hash
app.flash.to_hash
app.response # long, raw, HTML

次のようにRailsコンソールでメソッドにアクセスできます

controller.method_name
helper.method_name

レール3では、これを試してください:

session = ActionDispatch::Integration::Session.new(Rails.application)
session.get(url)
body = session.response.body

ボディには、URLのHTMLが含まれます。

ルーティングとレンダリングの方法(ディスパッチ)Rails 3のモデルから

以前の回答はヘルパーの呼び出しですが、以下はコントローラーメソッドの呼び出しに役立ちます。これをレール2.3.2で使用しました。

最初に、次のコードを.irbrcファイル(ホームディレクトリにある場合があります)に追加します

class Object
   def request(options = {})
     url=app.url_for(options)
     app.get(url)
     puts app.html_document.root.to_s    
  end
end

Railsコンソールでは、次のように入力できます...

request(:controller => :show, :action => :show_frontpage)

...そしてhtmlはコンソールにダンプされます。

コントローラーのアクションまたはビュー内で、 console メソッドを呼び出してコンソールを呼び出すことができます。

たとえば、コントローラー内:

class PostsController < ApplicationController
  def new
    console
    @post = Post.new
  end
end

またはビュー内:

<% console %>

<h2>New Post</h2>

これにより、ビュー内にコンソールがレンダリングされます。コンソール呼び出しの場所を気にする必要はありません。呼び出しの場所ではなく、HTMLコンテンツの隣にレンダリングされます。

参照: http://guides.rubyonrails.org/debugging_rails_applications.html

Railsコンソールでヘルパーメソッドをテストする方法の1つとして、

Struct.new(:t).extend(YourHelper).your_method(* arg)

およびリロードして実行

reload !; Struct.new(:t).extend(YourHelper).your_method(* arg)

コントローラーの場合、railsコンソールでコントローラーオブジェクトをインスタンス化できます。

たとえば、

class CustomPagesController < ApplicationController

  def index
    @customs = CustomPage.all
  end

  def get_number
    puts "Got the Number"
  end

  protected

  def get_private_number
    puts 'Got private Number'
  end

end

custom = CustomPagesController.new
2.1.5 :011 > custom = CustomPagesController.new
 => #<CustomPagesController:0xb594f77c @_action_has_layout=true, @_routes=nil, @_headers={"Content-Type"=>"text/html"}, @_status=200, @_request=nil, @_response=nil> 
2.1.5 :014 > custom.get_number
Got the Number
 => nil

# For calling private or protected methods,
2.1.5 :048 > custom.send(:get_private_number)
Got private Number
 => nil

独自のヘルパーを追加し、そのメソッドをコンソールで使用可能にしたい場合:

  1. コンソールで include YourHelperName
  2. を実行します
  3. ヘルパーメソッドがコンソールで使用可能になりました。コンソールで method_name(args)を呼び出して使用します。

例: 'app / helpers / my_helper.rb`にMyHelper(メソッド my_method )があり、コンソールで次の操作を実行するとします:

  1. MyHelperを含める
  2. my_helper.my_method
ライセンス: CC-BY-SA帰属
所属していません StackOverflow
scroll top