mirror of
https://github.com/rails/rails.git
synced 2022-11-09 12:12:34 -05:00
69b0e5c44a
git-svn-id: http://svn-commit.rubyonrails.org/rails/trunk@6120 5ecf4fe2-1ee6-0310-87b1-e25e094e27de
52 lines
1.4 KiB
Ruby
52 lines
1.4 KiB
Ruby
$:.unshift(File.dirname(__FILE__) + "/../lib")
|
|
|
|
require "action_controller"
|
|
require 'action_controller/test_process'
|
|
|
|
Person = Struct.new("Person", :name, :address, :age)
|
|
|
|
class BenchmarkController < ActionController::Base
|
|
def message
|
|
render_text "hello world"
|
|
end
|
|
|
|
def list
|
|
@people = [ Person.new("David"), Person.new("Mary") ]
|
|
render_template "hello: <% for person in @people %>Name: <%= person.name %><% end %>"
|
|
end
|
|
|
|
def form_helper
|
|
@person = Person.new "david", "hyacintvej", 24
|
|
render_template(
|
|
"<% person = Person.new 'Mary', 'hyacintvej', 22 %> " +
|
|
"change the name <%= text_field 'person', 'name' %> and <%= text_field 'person', 'address' %> and <%= text_field 'person', 'age' %>"
|
|
)
|
|
end
|
|
end
|
|
|
|
#ActionController::Base.view_paths = [ File.dirname(__FILE__) ]
|
|
|
|
require "benchmark"
|
|
|
|
RUNS = ARGV[0] ? ARGV[0].to_i : 50
|
|
|
|
require "profile" if ARGV[1]
|
|
|
|
runtime = Benchmark.measure {
|
|
RUNS.times { BenchmarkController.process_test(ActionController::TestRequest.new({ "action" => "list" })) }
|
|
}
|
|
|
|
puts "List: #{RUNS / runtime.real}"
|
|
|
|
|
|
runtime = Benchmark.measure {
|
|
RUNS.times { BenchmarkController.process_test(ActionController::TestRequest.new({ "action" => "message" })) }
|
|
}
|
|
|
|
puts "Message: #{RUNS / runtime.real}"
|
|
|
|
runtime = Benchmark.measure {
|
|
RUNS.times { BenchmarkController.process_test(ActionController::TestRequest.new({ "action" => "form_helper" })) }
|
|
}
|
|
|
|
puts "Form helper: #{RUNS / runtime.real}"
|