aboutsummaryrefslogtreecommitdiffstats
path: root/railties/lib/commands/perform/benchmark.rb
diff options
context:
space:
mode:
authorJeremy Kemper <jeremy@bitsweat.net>2005-10-14 18:58:07 +0000
committerJeremy Kemper <jeremy@bitsweat.net>2005-10-14 18:58:07 +0000
commit00656979fed99d4d16eefc795067a576ab1a1a91 (patch)
treef26ccc6c445e3a8432ca6f589be64d53cb32645f /railties/lib/commands/perform/benchmark.rb
parent32021552125544d7cc2f548b1684a9f476845d58 (diff)
downloadrails-00656979fed99d4d16eefc795067a576ab1a1a91.tar.gz
rails-00656979fed99d4d16eefc795067a576ab1a1a91.tar.bz2
rails-00656979fed99d4d16eefc795067a576ab1a1a91.zip
r3619@sedna: jeremy | 2005-10-14 14:41:24 -0700
move scripts r3622@sedna: jeremy | 2005-10-14 14:54:48 -0700 remove script/perform and script/process in favor of script/perform/profile, etc. git-svn-id: http://svn-commit.rubyonrails.org/rails/trunk@2587 5ecf4fe2-1ee6-0310-87b1-e25e094e27de
Diffstat (limited to 'railties/lib/commands/perform/benchmark.rb')
-rw-r--r--railties/lib/commands/perform/benchmark.rb26
1 files changed, 26 insertions, 0 deletions
diff --git a/railties/lib/commands/perform/benchmark.rb b/railties/lib/commands/perform/benchmark.rb
new file mode 100644
index 0000000000..b12cf57215
--- /dev/null
+++ b/railties/lib/commands/perform/benchmark.rb
@@ -0,0 +1,26 @@
+#!/usr/local/bin/ruby
+
+if ARGV.empty?
+ puts "Usage: ./script/perform benchmarker [times] 'Person.expensive_way' 'Person.another_expensive_way' ..."
+ exit 1
+end
+
+begin
+ N = Integer(ARGV.first)
+ ARGV.shift
+rescue ArgumentError
+ N = 1
+end
+
+require RAILS_ROOT + '/config/environment'
+require 'benchmark'
+include Benchmark
+
+# Don't include compilation in the benchmark
+ARGV.each { |expression| eval(expression) }
+
+bm(6) do |x|
+ ARGV.each_with_index do |expression, idx|
+ x.report("##{idx + 1}") { N.times { eval(expression) } }
+ end
+end