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"
|
|
|
|
|