-
Notifications
You must be signed in to change notification settings - Fork 125
/
Copy pathindex.js
95 lines (81 loc) · 2.61 KB
/
index.js
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
const benchmark = require('benchmark')
const ProgressBar = require('progress')
const util = require('../test/util')
const implementations = {
bindings: require('../bindings'),
elliptic: require('../elliptic'),
noble: require('../noble'),
ecdsa: require('./ecdsa')
}
let fixtureIndex = 0
const fixtures = new Array(1000)
function getNextFixture () {
const fixture = fixtures[fixtureIndex++]
if (fixtureIndex === fixtures.length) fixtureIndex = 0
return fixture
}
const progressBar = new ProgressBar(':percent (:current/:total), :elapseds elapsed, eta :etas', {
total: fixtures.length,
stream: util.progressStream
})
util.setSeed(util.env.seed)
for (let i = 0; i < fixtures.length; ++i) {
const fixture = {}
fixture.privateKey = util.getPrivateKey()
fixture.publicKey = util.getPublicKey(fixture.privateKey).compressed
fixture.message = util.getMessage()
fixture.sigObj = util.sign(fixture.message, fixture.privateKey)
fixtures[i] = fixture
progressBar.tick()
}
console.log('Create ' + fixtures.length + ' fixtures')
console.log('++++++++++++++++++++++++++++++++++++++++++++++++++')
function runSuite (suiteName, testFunctionGenerator) {
const suite = new benchmark.Suite(suiteName, {
onStart () {
console.log('Benchmarking: ' + suiteName)
console.log('--------------------------------------------------')
},
onCycle (event) {
console.log(String(event.target))
},
onError (event) {
console.error(event.target.error)
},
onComplete () {
console.log('==================================================')
}
})
for (const [name, impl] of Object.entries(implementations)) {
if (impl[suiteName] === undefined) continue
suite.add(name, testFunctionGenerator(impl), {
onStart () {
fixtureIndex = 0
},
onCycle () {
fixtureIndex = 0
}
})
}
suite.run()
}
runSuite('publicKeyCreate', (secp256k1) => () => {
const fixture = getNextFixture()
secp256k1.publicKeyCreate(fixture.privateKey)
})
runSuite('ecdsaSign', (secp256k1) => () => {
const fixture = getNextFixture()
secp256k1.ecdsaSign(fixture.message, fixture.privateKey)
})
runSuite('ecdsaVerify', (secp256k1) => () => {
const fixture = getNextFixture()
secp256k1.ecdsaVerify(fixture.sigObj.signature, fixture.message, fixture.publicKey)
})
runSuite('ecdsaRecover', (secp256k1) => () => {
const fixture = getNextFixture()
secp256k1.ecdsaRecover(fixture.sigObj.signature, fixture.sigObj.recid, fixture.message)
})
runSuite('ecdh', (secp256k1) => () => {
const fixture = getNextFixture()
secp256k1.ecdh(fixture.publicKey, fixture.privateKey)
})