aboutsummaryrefslogtreecommitdiff
path: root/benchmarks/js/benchmark_suite.js
diff options
context:
space:
mode:
authorYilun Chong <chongyilun250@sina.com>2018-08-10 11:07:04 -0700
committerGitHub <noreply@github.com>2018-08-10 11:07:04 -0700
commitba8692fbade4ba329cc4531e286ab5a8e0821d97 (patch)
tree408e6b10b1a052aac8e7a8048cae0e6a293e59ce /benchmarks/js/benchmark_suite.js
parentacd5b05e9f1ec2153574807463af0612267b6067 (diff)
parent5a95666f6e3f1cae3fdd790d992a45c0b64c3b13 (diff)
downloadprotobuf-ba8692fbade4ba329cc4531e286ab5a8e0821d97.tar.gz
protobuf-ba8692fbade4ba329cc4531e286ab5a8e0821d97.tar.bz2
protobuf-ba8692fbade4ba329cc4531e286ab5a8e0821d97.zip
Merge pull request #4951 from BSBandme/add_js_benchmark
Add JS and Protobuf.js benchmark, fix js's reader.skipGroup
Diffstat (limited to 'benchmarks/js/benchmark_suite.js')
-rw-r--r--benchmarks/js/benchmark_suite.js33
1 files changed, 33 insertions, 0 deletions
diff --git a/benchmarks/js/benchmark_suite.js b/benchmarks/js/benchmark_suite.js
new file mode 100644
index 00000000..c95024b2
--- /dev/null
+++ b/benchmarks/js/benchmark_suite.js
@@ -0,0 +1,33 @@
+var benchmark = require("benchmark");
+
+function newBenchmark(messageName, filename, language) {
+ var benches = [];
+ return {
+ suite: new benchmark.Suite(messageName + filename + language )
+ .on("add", function(event) {
+ benches.push(event.target);
+ })
+ .on("start", function() {
+ process.stdout.write(
+ "benchmarking message " + messageName
+ + " of dataset file " + filename
+ + "'s performance ..." + "\n\n");
+ })
+ .on("cycle", function(event) {
+ process.stdout.write(String(event.target) + "\n");
+ })
+ .on("complete", function() {
+ var getHz = function(bench) {
+ return 1 / (bench.stats.mean + bench.stats.moe);
+ }
+ benches.forEach(function(val, index) {
+ benches[index] = getHz(val);
+ });
+ }),
+ benches: benches
+ }
+}
+
+module.exports = {
+ newBenchmark: newBenchmark
+}