2017-08-24 18:41:47 +02:00
|
|
|
import assert from 'assert';
|
2017-11-08 13:16:43 -05:00
|
|
|
import { generate, IFullWallet } from 'ethereumjs-wallet';
|
2017-08-24 18:41:47 +02:00
|
|
|
const { exec } = require('child_process');
|
|
|
|
const ProgressBar = require('progress');
|
|
|
|
|
|
|
|
// FIXME pick a less magic number
|
|
|
|
const derivationRounds = 100;
|
|
|
|
const dockerImage = 'dternyak/eth-priv-to-addr';
|
|
|
|
const dockerTag = 'latest';
|
|
|
|
const bar = new ProgressBar(':percent :bar', { total: derivationRounds });
|
|
|
|
|
2017-09-24 19:06:28 -07:00
|
|
|
function promiseFromChildProcess(command): Promise<any> {
|
|
|
|
return new Promise((resolve, reject) => {
|
2017-08-24 18:41:47 +02:00
|
|
|
return exec(command, (err, stdout) => {
|
|
|
|
err ? reject(err) : resolve(stdout);
|
|
|
|
});
|
|
|
|
});
|
|
|
|
}
|
|
|
|
|
2017-11-08 13:16:43 -05:00
|
|
|
async function privToAddrViaDocker(privKeyWallet: IFullWallet) {
|
2017-11-12 14:45:52 -05:00
|
|
|
const command = `docker run -e key=${privKeyWallet.getPrivateKeyString()} ${
|
|
|
|
dockerImage
|
|
|
|
}:${dockerTag}`;
|
2017-08-24 18:41:47 +02:00
|
|
|
const dockerOutput = await promiseFromChildProcess(command);
|
|
|
|
const newlineStrippedDockerOutput = dockerOutput.replace(
|
|
|
|
/(\r\n|\n|\r)/gm,
|
|
|
|
''
|
|
|
|
);
|
|
|
|
return newlineStrippedDockerOutput;
|
|
|
|
}
|
|
|
|
|
|
|
|
async function testDerivation() {
|
2017-11-08 13:16:43 -05:00
|
|
|
const privKeyWallet = generate();
|
|
|
|
const privKeyWalletAddress = await privKeyWallet.getAddressString();
|
2017-08-24 18:41:47 +02:00
|
|
|
const dockerAddr = await privToAddrViaDocker(privKeyWallet);
|
|
|
|
// strip the checksum
|
|
|
|
const lowerCasedPrivKeyWalletAddress = privKeyWalletAddress.toLowerCase();
|
|
|
|
// ensure that pyethereum privToAddr derivation matches our (js based) derivation
|
|
|
|
assert.strictEqual(dockerAddr, lowerCasedPrivKeyWalletAddress);
|
|
|
|
}
|
|
|
|
|
|
|
|
async function testDerivationNTimes(n = derivationRounds) {
|
|
|
|
let totalRounds = 0;
|
|
|
|
while (totalRounds < n) {
|
|
|
|
await testDerivation();
|
|
|
|
bar.tick();
|
|
|
|
totalRounds += 1;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
console.log('Starting testing...');
|
|
|
|
console.time('testDerivationNTimes');
|
|
|
|
testDerivationNTimes().then(() => {
|
|
|
|
console.timeEnd('testDerivationNTimes');
|
|
|
|
console.log(`Succeeded testing derivation ${derivationRounds} times :)`);
|
|
|
|
process.exit(0);
|
|
|
|
});
|