当我加载脚本/控制台时,有时我想使用控制器或视图助手方法的输出。

有没有办法:

模拟一个请求? 从控制器实例调用方法说请求? 测试助手方法,无论是通过所说的控制器实例或其他方式?


当前回答

你可以像下面这样在Ruby on Rails控制台中访问你的方法:

controller.method_name
helper.method_name

其他回答

前面的答案是调用助手,但下面的答案将有助于调用控制器方法。我已经在Ruby on Rails 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

然后在Ruby on Rails控制台中,您可以键入类似于……

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

...HTML将被转储到控制台。

在Ruby on Rails 3中,试试这个:

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

主体将包含URL的HTML。

如何路由和呈现(调度)从一个模型在Ruby on Rails 3

要调用helper,请使用helper对象:

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

如果你想使用一个默认情况下没有包含的helper(比如,因为你从ApplicationController中删除了helper:all),只需要包含这个helper。

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

至于如何处理控制器,我引用Nick的回答:

get '/posts/1' > response = app.response #您现在有了一个rails响应对象,就像集成测试一样 >反应。body #给你HTML >反应。cookie #散列的cookie # etc, etc

你可以像下面这样在Ruby on Rails控制台中访问你的方法:

controller.method_name
helper.method_name

如果你需要从控制台进行测试(在Ruby on 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..."

控制器方法:

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}

自由模块:

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