diff options
author | Jeremy Kemper <jeremy@bitsweat.net> | 2009-05-14 01:56:07 -0700 |
---|---|---|
committer | Jeremy Kemper <jeremy@bitsweat.net> | 2009-05-14 02:01:08 -0700 |
commit | c286952050e8fe16b0f6d64ba0687b52cc8f2ae1 (patch) | |
tree | 38dc6ad83ca0d4ae2695ca85793baa38ce06ea55 /actionpack/examples | |
parent | 5dd29c466c38a1bc395da579fd4b22c5e5a8e9fd (diff) | |
download | rails-c286952050e8fe16b0f6d64ba0687b52cc8f2ae1.tar.gz rails-c286952050e8fe16b0f6d64ba0687b52cc8f2ae1.tar.bz2 rails-c286952050e8fe16b0f6d64ba0687b52cc8f2ae1.zip |
Minimal base/new_base comparison
Diffstat (limited to 'actionpack/examples')
-rw-r--r-- | actionpack/examples/minimal.rb | 34 | ||||
-rw-r--r-- | actionpack/examples/simple.rb | 17 |
2 files changed, 34 insertions, 17 deletions
diff --git a/actionpack/examples/minimal.rb b/actionpack/examples/minimal.rb new file mode 100644 index 0000000000..84a8499daf --- /dev/null +++ b/actionpack/examples/minimal.rb @@ -0,0 +1,34 @@ +$LOAD_PATH.unshift "#{File.dirname(__FILE__)}/../lib" +require 'action_controller' +require 'action_controller/new_base' if ENV['NEW'] +require 'benchmark' + +class BaseController < ActionController::Base + def index + render :text => '' + end +end + +n = (ENV['N'] || 10000).to_i +input = StringIO.new('') + +def call_index(controller, input, n) + n.times do + controller.action(:index).call({ 'rack.input' => input }) + end + + puts controller.name + status, headers, body = controller.action(:index).call({ 'rack.input' => input }) + + puts status + puts headers.to_yaml + puts '---' + body.each do |part| + puts part + end + puts '---' +end + +elapsed = Benchmark.realtime { call_index BaseController, input, n } + +puts "%dms elapsed, %d requests/sec" % [1000 * elapsed, n / elapsed] diff --git a/actionpack/examples/simple.rb b/actionpack/examples/simple.rb deleted file mode 100644 index 4ecb824688..0000000000 --- a/actionpack/examples/simple.rb +++ /dev/null @@ -1,17 +0,0 @@ -$LOAD_PATH.unshift "#{File.dirname(__FILE__)}/../lib" -require 'action_controller' - -class PeopleController < ActionController::Base - def index - head :ok - end -end - -status, headers, body = PeopleController.action(:index).call({ 'rack.input' => StringIO.new('') }) - -puts status -puts headers.to_yaml -puts '---' -body.each do |part| - puts part -end |