mini_racer/benchmark/exec_js_uglify/bench.rb

51 lines
1.3 KiB
Ruby
Raw Normal View History

2016-05-14 13:14:14 +00:00
engines = {
2016-05-16 05:58:19 +00:00
mini_racer: proc { ExecJS::MiniRacerRuntime.new },
therubyracer: proc { ExecJS::RubyRacerRuntime.new },
rhino: proc { ExecJS::RubyRhinoRuntime.new },
duktape: proc { ExecJS::DuktapeRuntime.new},
node: proc { ExecJS::Runtimes::Node }
2016-05-14 13:14:14 +00:00
}
engine = ARGV[0]
2016-05-16 05:58:19 +00:00
unless engine && (execjs_engine = engines[engine.to_sym])
2016-05-14 13:14:14 +00:00
STDERR.puts "Unknown engine try #{engines.keys.join(',')}"
exit 1
2016-05-12 02:41:33 +00:00
end
2016-05-16 06:47:57 +00:00
unless defined? Bundler
if engine == "therubyracer"
system 'RR=1 bundle'
exec "RR=1 bundle exec ruby bench.rb #{ARGV[0]}"
else
system 'bundle'
exec "bundle exec ruby bench.rb #{ARGV[0]}"
end
end
2016-05-14 13:14:14 +00:00
unless engine == "node"
require engine
end
2016-05-16 05:58:19 +00:00
2016-05-14 13:14:14 +00:00
puts "Benching with #{engine}"
2016-05-12 02:41:33 +00:00
require 'uglifier'
2016-05-16 05:58:19 +00:00
ExecJS.runtime = execjs_engine.call
2016-05-12 02:41:33 +00:00
start = Time.new
2016-05-16 06:47:57 +00:00
Uglifier.compile(File.read("helper_files/discourse_app.js"))
2016-05-12 02:41:33 +00:00
puts "#{engine} minify discourse_app.js #{(Time.new - start)*1000}ms"
start = Time.new
2016-05-16 06:47:57 +00:00
Uglifier.compile(File.read("helper_files/discourse_app_minified.js"))
2016-05-12 02:41:33 +00:00
puts "#{engine} minify discourse_app_minified.js #{(Time.new - start)*1000}ms"
start = Time.new
(0..1).map do
Thread.new do
2016-05-16 06:47:57 +00:00
Uglifier.compile(File.read("helper_files/discourse_app.js"))
2016-05-12 02:41:33 +00:00
end
end.each(&:join)
puts "#{engine} minify discourse_app.js twice (2 threads) #{(Time.new - start)*1000}ms"