|
1 | | -'use strict'; |
| 1 | +"use strict"; |
2 | 2 |
|
3 | | -var benchmark = require('benchmark'); |
4 | | -var dashdRPC = require('@dashevo/dashd-rpc'); |
5 | | -var async = require('async'); |
| 3 | +var benchmark = require("benchmark"); |
| 4 | +var dashdRPC = require("@dashevo/dashd-rpc"); |
| 5 | +var async = require("async"); |
6 | 6 | var maxTime = 20; |
7 | 7 |
|
8 | | -console.log('Dash Service native interface vs. Dash JSON RPC interface'); |
9 | | -console.log('----------------------------------------------------------------------'); |
| 8 | +console.log("Dash Service native interface vs. Dash JSON RPC interface"); |
| 9 | +console.log("----------------------------------------------------------------------"); |
10 | 10 |
|
11 | 11 | // To run the benchmarks a fully synced Dash Core directory is needed. The RPC comands |
12 | 12 | // can be modified to match the settings in dash.conf. |
13 | 13 |
|
14 | 14 | var fixtureData = { |
15 | 15 | blockHashes: [ |
16 | | - '00000000fa7a4acea40e5d0591d64faf48fd862fa3561d111d967fc3a6a94177', |
17 | | - '000000000017e9e0afc4bc55339f60ffffb9cbe883f7348a9fbc198a486d5488', |
18 | | - '000000000019ddb889b534c5d85fca2c91a73feef6fd775cd228dea45353bae1', |
19 | | - '0000000000977ac3d9f5261efc88a3c2d25af92a91350750d00ad67744fa8d03' |
| 16 | + "00000000fa7a4acea40e5d0591d64faf48fd862fa3561d111d967fc3a6a94177", |
| 17 | + "000000000017e9e0afc4bc55339f60ffffb9cbe883f7348a9fbc198a486d5488", |
| 18 | + "000000000019ddb889b534c5d85fca2c91a73feef6fd775cd228dea45353bae1", |
| 19 | + "0000000000977ac3d9f5261efc88a3c2d25af92a91350750d00ad67744fa8d03", |
20 | 20 | ], |
21 | 21 | txHashes: [ |
22 | | - '5523b432c1bd6c101bee704ad6c560fd09aefc483f8a4998df6741feaa74e6eb', |
23 | | - 'ff48393e7731507c789cfa9cbfae045b10e023ce34ace699a63cdad88c8b43f8', |
24 | | - '5d35c5eebf704877badd0a131b0a86588041997d40dbee8ccff21ca5b7e5e333', |
25 | | - '88842f2cf9d8659c3434f6bc0c515e22d87f33e864e504d2d7117163a572a3aa', |
26 | | - ] |
| 22 | + "5523b432c1bd6c101bee704ad6c560fd09aefc483f8a4998df6741feaa74e6eb", |
| 23 | + "ff48393e7731507c789cfa9cbfae045b10e023ce34ace699a63cdad88c8b43f8", |
| 24 | + "5d35c5eebf704877badd0a131b0a86588041997d40dbee8ccff21ca5b7e5e333", |
| 25 | + "88842f2cf9d8659c3434f6bc0c515e22d87f33e864e504d2d7117163a572a3aa", |
| 26 | + ], |
27 | 27 | }; |
28 | 28 |
|
29 | | -var dashd = require('../').services.Dash({ |
| 29 | +var dashd = require("../").services.Dash({ |
30 | 30 | node: { |
31 | | - datadir: process.env.HOME + '/.dash', |
| 31 | + datadir: process.env.HOME + "/.dash", |
32 | 32 | network: { |
33 | | - name: 'testnet' |
34 | | - } |
35 | | - } |
| 33 | + name: "testnet", |
| 34 | + }, |
| 35 | + }, |
36 | 36 | }); |
37 | 37 |
|
38 | | -dashd.on('error', function(err) { |
| 38 | +dashd.on("error", function (err) { |
39 | 39 | console.error(err.message); |
40 | 40 | }); |
41 | 41 |
|
42 | | -dashd.start(function(err) { |
| 42 | +dashd.start(function (err) { |
43 | 43 | if (err) { |
44 | 44 | throw err; |
45 | 45 | } |
46 | | - console.log('Dash Core started'); |
| 46 | + console.log("Dash Core started"); |
47 | 47 | }); |
48 | 48 |
|
49 | | -dashd.on('ready', function() { |
50 | | - |
51 | | - console.log('Dash Core ready'); |
| 49 | +dashd.on("ready", function () { |
| 50 | + console.log("Dash Core ready"); |
52 | 51 |
|
53 | 52 | var client = new dashdRPC({ |
54 | | - host: 'localhost', |
| 53 | + host: "localhost", |
55 | 54 | port: 18332, |
56 | | - user: 'dash', |
57 | | - pass: 'local321' |
| 55 | + user: "dash", |
| 56 | + pass: "local321", |
58 | 57 | }); |
59 | 58 |
|
60 | | - async.series([ |
61 | | - function(next) { |
62 | | - |
63 | | - var c = 0; |
64 | | - var hashesLength = fixtureData.blockHashes.length; |
65 | | - var txLength = fixtureData.txHashes.length; |
| 59 | + async.series( |
| 60 | + [ |
| 61 | + function (next) { |
| 62 | + var c = 0; |
| 63 | + var hashesLength = fixtureData.blockHashes.length; |
| 64 | + var txLength = fixtureData.txHashes.length; |
66 | 65 |
|
67 | | - function dashdGetBlockNative(deffered) { |
68 | | - if (c >= hashesLength) { |
69 | | - c = 0; |
70 | | - } |
71 | | - var hash = fixtureData.blockHashes[c]; |
72 | | - dashd.getBlock(hash, function(err, block) { |
73 | | - if (err) { |
74 | | - throw err; |
| 66 | + function dashdGetBlockNative(deffered) { |
| 67 | + if (c >= hashesLength) { |
| 68 | + c = 0; |
75 | 69 | } |
76 | | - deffered.resolve(); |
77 | | - }); |
78 | | - c++; |
79 | | - } |
80 | | - |
81 | | - function dashdGetBlockJsonRpc(deffered) { |
82 | | - if (c >= hashesLength) { |
83 | | - c = 0; |
| 70 | + var hash = fixtureData.blockHashes[c]; |
| 71 | + dashd.getBlock(hash, function (err, block) { |
| 72 | + if (err) { |
| 73 | + throw err; |
| 74 | + } |
| 75 | + deffered.resolve(); |
| 76 | + }); |
| 77 | + c++; |
84 | 78 | } |
85 | | - var hash = fixtureData.blockHashes[c]; |
86 | | - client.getBlock(hash, false, function(err, block) { |
87 | | - if (err) { |
88 | | - throw err; |
89 | | - } |
90 | | - deffered.resolve(); |
91 | | - }); |
92 | | - c++; |
93 | | - } |
94 | 79 |
|
95 | | - function dashGetTransactionNative(deffered) { |
96 | | - if (c >= txLength) { |
97 | | - c = 0; |
98 | | - } |
99 | | - var hash = fixtureData.txHashes[c]; |
100 | | - dashd.getTransaction(hash, true, function(err, tx) { |
101 | | - if (err) { |
102 | | - throw err; |
| 80 | + function dashdGetBlockJsonRpc(deffered) { |
| 81 | + if (c >= hashesLength) { |
| 82 | + c = 0; |
103 | 83 | } |
104 | | - deffered.resolve(); |
105 | | - }); |
106 | | - c++; |
107 | | - } |
| 84 | + var hash = fixtureData.blockHashes[c]; |
| 85 | + client.getBlock(hash, false, function (err, block) { |
| 86 | + if (err) { |
| 87 | + throw err; |
| 88 | + } |
| 89 | + deffered.resolve(); |
| 90 | + }); |
| 91 | + c++; |
| 92 | + } |
108 | 93 |
|
109 | | - function dashGetTransactionJsonRpc(deffered) { |
110 | | - if (c >= txLength) { |
111 | | - c = 0; |
| 94 | + function dashGetTransactionNative(deffered) { |
| 95 | + if (c >= txLength) { |
| 96 | + c = 0; |
| 97 | + } |
| 98 | + var hash = fixtureData.txHashes[c]; |
| 99 | + dashd.getTransaction(hash, true, function (err, tx) { |
| 100 | + if (err) { |
| 101 | + throw err; |
| 102 | + } |
| 103 | + deffered.resolve(); |
| 104 | + }); |
| 105 | + c++; |
112 | 106 | } |
113 | | - var hash = fixtureData.txHashes[c]; |
114 | | - client.getRawTransaction(hash, function(err, tx) { |
115 | | - if (err) { |
116 | | - throw err; |
| 107 | + |
| 108 | + function dashGetTransactionJsonRpc(deffered) { |
| 109 | + if (c >= txLength) { |
| 110 | + c = 0; |
117 | 111 | } |
118 | | - deffered.resolve(); |
119 | | - }); |
120 | | - c++; |
121 | | - } |
| 112 | + var hash = fixtureData.txHashes[c]; |
| 113 | + client.getRawTransaction(hash, function (err, tx) { |
| 114 | + if (err) { |
| 115 | + throw err; |
| 116 | + } |
| 117 | + deffered.resolve(); |
| 118 | + }); |
| 119 | + c++; |
| 120 | + } |
122 | 121 |
|
123 | | - var suite = new benchmark.Suite(); |
| 122 | + var suite = new benchmark.Suite(); |
124 | 123 |
|
125 | | - suite.add('dashd getblock (native)', dashdGetBlockNative, { |
126 | | - defer: true, |
127 | | - maxTime: maxTime |
128 | | - }); |
| 124 | + suite.add("dashd getblock (native)", dashdGetBlockNative, { |
| 125 | + defer: true, |
| 126 | + maxTime: maxTime, |
| 127 | + }); |
129 | 128 |
|
130 | | - suite.add('dashd getblock (json rpc)', dashdGetBlockJsonRpc, { |
131 | | - defer: true, |
132 | | - maxTime: maxTime |
133 | | - }); |
| 129 | + suite.add("dashd getblock (json rpc)", dashdGetBlockJsonRpc, { |
| 130 | + defer: true, |
| 131 | + maxTime: maxTime, |
| 132 | + }); |
134 | 133 |
|
135 | | - suite.add('dashd gettransaction (native)', dashGetTransactionNative, { |
136 | | - defer: true, |
137 | | - maxTime: maxTime |
138 | | - }); |
| 134 | + suite.add("dashd gettransaction (native)", dashGetTransactionNative, { |
| 135 | + defer: true, |
| 136 | + maxTime: maxTime, |
| 137 | + }); |
139 | 138 |
|
140 | | - suite.add('dashd gettransaction (json rpc)', dashGetTransactionJsonRpc, { |
141 | | - defer: true, |
142 | | - maxTime: maxTime |
143 | | - }); |
| 139 | + suite.add("dashd gettransaction (json rpc)", dashGetTransactionJsonRpc, { |
| 140 | + defer: true, |
| 141 | + maxTime: maxTime, |
| 142 | + }); |
144 | 143 |
|
145 | | - suite |
146 | | - .on('cycle', function(event) { |
147 | | - console.log(String(event.target)); |
148 | | - }) |
149 | | - .on('complete', function() { |
150 | | - console.log('Fastest is ' + this.filter('fastest').pluck('name')); |
151 | | - console.log('----------------------------------------------------------------------'); |
152 | | - next(); |
153 | | - }) |
154 | | - .run(); |
155 | | - } |
156 | | - ], function(err) { |
157 | | - if (err) { |
158 | | - throw err; |
159 | | - } |
160 | | - console.log('Finished'); |
161 | | - dashd.stop(function(err) { |
| 144 | + suite |
| 145 | + .on("cycle", function (event) { |
| 146 | + console.log(String(event.target)); |
| 147 | + }) |
| 148 | + .on("complete", function () { |
| 149 | + console.log("Fastest is " + this.filter("fastest").pluck("name")); |
| 150 | + console.log("----------------------------------------------------------------------"); |
| 151 | + next(); |
| 152 | + }) |
| 153 | + .run(); |
| 154 | + }, |
| 155 | + ], |
| 156 | + function (err) { |
162 | 157 | if (err) { |
163 | | - console.error('Fail to stop services: ' + err); |
164 | | - process.exit(1); |
| 158 | + throw err; |
165 | 159 | } |
166 | | - process.exit(0); |
167 | | - }); |
168 | | - }); |
| 160 | + console.log("Finished"); |
| 161 | + dashd.stop(function (err) { |
| 162 | + if (err) { |
| 163 | + console.error("Fail to stop services: " + err); |
| 164 | + process.exit(1); |
| 165 | + } |
| 166 | + process.exit(0); |
| 167 | + }); |
| 168 | + } |
| 169 | + ); |
169 | 170 | }); |
0 commit comments