aboutsummaryrefslogtreecommitdiff
path: root/benchmarks/js
diff options
context:
space:
mode:
authorYilun Chong <yilunchong@google.com>2018-07-20 16:13:19 -0700
committerYilun Chong <yilunchong@google.com>2018-07-20 16:13:19 -0700
commita7071291c750fe2b1b8a20c155f4e3dd5a38db24 (patch)
tree5f5407575a5344bd7451b3544f3ffabd2a8963ea /benchmarks/js
parent88795f64e4c5dc870c63b3d4d39924cc91590b2f (diff)
downloadprotobuf-a7071291c750fe2b1b8a20c155f4e3dd5a38db24.tar.gz
protobuf-a7071291c750fe2b1b8a20c155f4e3dd5a38db24.tar.bz2
protobuf-a7071291c750fe2b1b8a20c155f4e3dd5a38db24.zip
Add JS and Protobuf.js benchmark
Diffstat (limited to 'benchmarks/js')
-rw-r--r--benchmarks/js/BenchmarkSuite.js33
-rw-r--r--benchmarks/js/JsBenchmark.js69
2 files changed, 102 insertions, 0 deletions
diff --git a/benchmarks/js/BenchmarkSuite.js b/benchmarks/js/BenchmarkSuite.js
new file mode 100644
index 00000000..73ab373c
--- /dev/null
+++ b/benchmarks/js/BenchmarkSuite.js
@@ -0,0 +1,33 @@
+var benchmark = require("./node_modules/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
+}
diff --git a/benchmarks/js/JsBenchmark.js b/benchmarks/js/JsBenchmark.js
new file mode 100644
index 00000000..bf182449
--- /dev/null
+++ b/benchmarks/js/JsBenchmark.js
@@ -0,0 +1,69 @@
+require('./datasets/google_message1/proto2/benchmark_message1_proto2_pb.js');
+require('./datasets/google_message1/proto3/benchmark_message1_proto3_pb.js');
+require('./datasets/google_message2/benchmark_message2_pb.js');
+require('./datasets/google_message3/benchmark_message3_pb.js');
+require('./datasets/google_message4/benchmark_message4_pb.js');
+require('./benchmarks_pb.js');
+
+var fs = require('fs');
+var benchmarkSuite = require("./BenchmarkSuite.js");
+
+
+function getNewPrototype(name) {
+ var message = eval("proto." + name);
+ if (typeof(message) == "undefined") {
+ throw "type " + name + " is undefined";
+ }
+ return message;
+}
+
+var results = [];
+
+console.log("#####################################################");
+console.log("Js Benchmark: ");
+process.argv.forEach(function(filename, index) {
+ if (index < 2) {
+ return;
+ }
+ var benchmarkDataset =
+ proto.benchmarks.BenchmarkDataset.deserializeBinary(fs.readFileSync(filename));
+ var messageList = [];
+ var totalBytes = 0;
+ benchmarkDataset.getPayloadList().forEach(function(onePayload) {
+ var message = getNewPrototype(benchmarkDataset.getMessageName());
+ messageList.push(message.deserializeBinary(onePayload));
+ totalBytes += onePayload.length;
+ });
+
+ var senarios = benchmarkSuite.newBenchmark(
+ benchmarkDataset.getMessageName(), filename, "js");
+ senarios.suite
+ .add("js deserialize", function() {
+ benchmarkDataset.getPayloadList().forEach(function(onePayload) {
+ var protoType = getNewPrototype(benchmarkDataset.getMessageName());
+ protoType.deserializeBinary(onePayload);
+ });
+ })
+ .add("js serialize", function() {
+ var protoType = getNewPrototype(benchmarkDataset.getMessageName());
+ messageList.forEach(function(message) {
+ message.serializeBinary();
+ });
+ })
+ .run({"Async": false});
+
+ results.push({
+ filename: filename,
+ benchmarks: {
+ protobufjs_decoding: senarios.benches[0] * totalBytes,
+ protobufjs_encoding: senarios.benches[1] * totalBytes
+ }
+ })
+
+ console.log("Throughput for deserialize: "
+ + senarios.benches[0] * totalBytes / 1024 / 1024 + "MB/s" );
+ console.log("Throughput for serialize: "
+ + senarios.benches[1] * totalBytes / 1024 / 1024 + "MB/s" );
+ console.log("");
+});
+console.log("#####################################################"); \ No newline at end of file