From 6689c1347ff9e7dd65e222c3437bff9484a9fda8 Mon Sep 17 00:00:00 2001 From: Ivan Socolsky Date: Tue, 10 Feb 2015 13:20:41 -0300 Subject: [PATCH] add testdata --- test/integration.js | 181 ++++++++++++++++++-------------------------- test/testdata.js | 76 +++++++++++++++++++ 2 files changed, 150 insertions(+), 107 deletions(-) create mode 100644 test/testdata.js diff --git a/test/integration.js b/test/integration.js index 1f7ab7b..bd73483 100644 --- a/test/integration.js +++ b/test/integration.js @@ -18,45 +18,7 @@ var Wallet = require('../lib/model/wallet'); var Address = require('../lib/model/address'); var Copayer = require('../lib/model/copayer'); var CopayServer = require('../lib/server'); - -var keyPair = { - priv: '0dea92f1df6675085b5cdd965487bb862f84f2755bcb56fa45dbf5b387a6c4a0', - pub: '026092daeed8ecb2212869395770e956ffc9bf453f803e700f64ffa70c97a00d80', -}; - - -var aPubKey = '042F65F56A6C06C2B651C473AC221B2460DA57859AFB72564E9781B655EBC0AFAF322B9A732324ECC92A3319DFB1F0D53F0CB7E6620C98BD1EF53106A7CF3F6DB9'; -var aXPubKey = 'xpub661MyMwAqRbcFHFFvUP6HaKdd2FYzNcZCGagxMzQEf1J3x2DeASBW2JWox7ToGwPM7V2yRzQAxcD6MdPid9C8kwhKkVWBxQ3dMo8zu3pub7'; -var aXPubKeySignature = '3045022100f988737147894bbfdc196c1289e4d970b391c0d8e9d1fcc0397f16e6a31c9df2022014d9af9aceccb540f4a5a2680e2aebb1f3df55bcf3778599b78314a02064c592'; // with keyPair.priv - -// Copayers - -var someXPrivKey = [ - 'xprv9s21ZrQH143K2rMHbXTJmWTuFx6ssqn1vyRoZqPkCXYchBSkp5ey8kMJe84sxfXq5uChWH4gk94rWbXZt2opN9kg4ufKGvUM7HQSLjnoh7e', -]; - -var someXPubKeys = [ - 'xpub661MyMwAqRbcFLRkhYzK8eQdoywNHJVsJCMQNDoMks5bZymuMcyDgYfnVQYq2Q9npnVmdTAthYGc3N3uxm5sEdnTpSqBc4YYTAhNnoSxCm9', - 'xpub661MyMwAqRbcEzHgVwwxoXksq21rRNsJsn7AFy4VD4PzsEmjjWwsyEiTjsdQviXbqZ5yHVWJR8zFUDgUKkq4R97su3UyNo36Z8hSaCPrv6o', - 'xpub661MyMwAqRbcFXUfkjfSaRwxJbAPpzNUvTiNFjgZwDJ8sZuhyodkP24L4LvsrgThYAAwKkVVSSmL7Ts7o9EHEHPB3EE89roAra7njoSeiMd', - 'xpub661MyMwAqRbcGpExxHEzAWxBQX3k76NyerSpjqucSXXfTqH6Wq9sUVRwTjpHZHwapDbG16KEB9w9r3LT2jKYqU9xJf1YBAaZFikbUHiV1tg', - 'xpub661MyMwAqRbcEvKQnt9ELHHcangXssm174sWr5gNTSmQYsAtvQJNUpLETDTm1vDxwtABvB4SRjGkNMm37NnMerKg4e3ygqmWEr75Fka4dK7', - 'xpub661MyMwAqRbcG67ioS7rz3fFg7EDQNLJ9m1etAPwBecZhL5kKAKe4JU5jCTzRcEWp28XCYA1gKh7jyficSr97gcR2pjDL5jbWua1CwTKWV4', -]; - -// with keyPair.priv -var someXPubKeysSignatures = [ - '30440220192ae7345d980f45f908bd63ccad60ce04270d07b91f1a9d92424a07a38af85202201591f0f71dd4e79d9206d2306862e6b8375e13a62c193953d768e884b6fb5a46', - '30440220134d13139323ba16ff26471c415035679ee18b2281bf85550ccdf6a370899153022066ef56ff97091b9be7dede8e40f50a3a8aad8205f2e3d8e194f39c20f3d15c62', - '304402207a4e7067d823a98fa634f9c9d991b8c42cd0f82da24f686992acf96cdeb5e387022021ceba729bf763fc8e4277f6851fc2b856a82a22b35f20d2eeb23d99c5f5a41c', - '304402203ae5bf7fa8935b8ab2ac33724dbb191356cecb47c8371d2c9389e918a3600918022073b48705306730c8fe4ab22d5f6ed3ca3def27eb6e8c5cc8f53e23c11fa5e5ef', - '3045022100eabd2a605403b377a8db9eec57726da0309a7eb385e7e4e5273b9862046f25ef02204d18755a90580a98f45e162ae5d5dc39aa3aa708a0d79433ed259e70a832b49c', - '3045022100c282254773c65025054e18a61ee550cbf78b88fc72ef66770050815b62502d9c02206e0df528203c9201c144f865df71f5d2471668f4ed8387979fcee20f6fa121a9', -]; - -//Copayer signature -var aText = 'hello world'; -var aTextSignature = '3045022100addd20e5413865d65d561ad2979f2289a40d52594b1f804840babd9a63e4ebbf02204b86285e1fcab02df772e7a1325fc4b511ecad79a8f80a2bd1ad8bfa858ac3d4'; // with someXPrivKey[0].derive('m/1/0')=5c0e043a513032907d181325a8e7990b076c0af15ed13dc5e611cda9bb3ae52a; +var TestData = require('./testdata'); var helpers = {}; @@ -82,18 +44,17 @@ helpers.createAndJoinWallet = function(m, n, cb) { name: 'a wallet', m: m, n: n, - pubKey: keyPair.pub, + pubKey: TestData.keyPair.pub, }; server.createWallet(walletOpts, function(err, walletId) { if (err) return cb(err); - async.each(_.range(1, n + 1), function(i, cb) { - + async.each(_.range(n), function(i, cb) { var copayerOpts = { walletId: walletId, - name: 'copayer ' + i, - xPubKey: someXPubKeys[i - 1], - xPubKeySignature: someXPubKeysSignatures[i - 1], + name: 'copayer ' + (i + 1), + xPubKey: TestData.copayers[i].xPubKey, + xPubKeySignature: TestData.copayers[i].xPubKeySignature, }; server.joinWallet(copayerOpts, function(err, copayerId) { @@ -105,7 +66,7 @@ helpers.createAndJoinWallet = function(m, n, cb) { helpers.getAuthServer(copayerIds[0], function(s) { s.getWallet({}, function(err, w) { - cb(s, w); + cb(s, w, _.take(TestData.copayers, w.n)); }); }); }); @@ -173,7 +134,7 @@ helpers.clientSign = function(tx, xpriv, n) { //Derive proper key to sign, for each input var privs = [], derived = {}; - var xpriv = new Bitcore.HDPrivateKey(someXPrivKey[0]); + var xpriv = new Bitcore.HDPrivateKey(TestData.copayers[0].xPrivKey); _.each(tx.inputs, function(i) { if (!derived[i.path]) { @@ -201,10 +162,9 @@ helpers.clientSign = function(tx, xpriv, n) { return signatures; }; -helpers.addProposalSignature = function(server, wallet, txOpts) { +helpers.addProposalSignature = function(txOpts, privKey) { var msg = txOpts.toAddress + '|' + txOpts.amount + '|' + txOpts.message; - var copayer = wallet.getCopayer(server.copayerId); - txOpts.proposalSignature = SignUtils.sign(msg, copayer.signingPubKey); + txOpts.proposalSignature = SignUtils.sign(msg, privKey); }; var db, storage; @@ -244,7 +204,7 @@ describe('Copay server', function() { name: 'my wallet', m: 2, n: 3, - pubKey: aPubKey, + pubKey: TestData.keyPair.pub, }; server.createWallet(opts, function(err, walletId) { should.not.exist(err); @@ -262,7 +222,7 @@ describe('Copay server', function() { name: '', m: 2, n: 3, - pubKey: aPubKey, + pubKey: TestData.keyPair.pub, }; server.createWallet(opts, function(err, walletId) { should.not.exist(walletId); @@ -295,7 +255,7 @@ describe('Copay server', function() { var opts = { id: '123', name: 'my wallet', - pubKey: aPubKey, + pubKey: TestData.keyPair.pub, }; async.each(invalidPairs, function(pair, cb) { opts.m = pair.m; @@ -319,7 +279,7 @@ describe('Copay server', function() { name: 'my wallet', m: 2, n: 3, - pubKey: keyPair.pub, + pubKey: TestData.keyPair.pub, }; server.createWallet(walletOpts, function(err, wId) { should.not.exist(err); @@ -333,8 +293,8 @@ describe('Copay server', function() { var copayerOpts = { walletId: walletId, name: 'me', - xPubKey: aXPubKey, - xPubKeySignature: aXPubKeySignature, + xPubKey: TestData.copayers[0].xPubKey, + xPubKeySignature: TestData.copayers[0].xPubKeySignature, }; server.joinWallet(copayerOpts, function(err, copayerId) { should.not.exist(err); @@ -355,8 +315,8 @@ describe('Copay server', function() { var copayerOpts = { walletId: walletId, name: '', - xPubKey: someXPubKeys[0], - xPubKeySignature: someXPubKeysSignatures[0], + xPubKey: TestData.copayers[0].xPubKey, + xPubKeySignature: TestData.copayers[0].xPubKeySignature, }; server.joinWallet(copayerOpts, function(err, copayerId) { should.not.exist(copayerId); @@ -384,8 +344,8 @@ describe('Copay server', function() { var copayerOpts = { walletId: wallet.id, name: 'me', - xPubKey: someXPubKeys[1], - xPubKeySignature: someXPubKeysSignatures[1], + xPubKey: TestData.copayers[1].xPubKey, + xPubKeySignature: TestData.copayers[1].xPubKeySignature, }; server.joinWallet(copayerOpts, function(err) { should.exist(err); @@ -400,8 +360,8 @@ describe('Copay server', function() { var copayerOpts = { walletId: walletId, name: 'me', - xPubKey: someXPubKeys[0], - xPubKeySignature: someXPubKeysSignatures[0], + xPubKey: TestData.copayers[0].xPubKey, + xPubKeySignature: TestData.copayers[0].xPubKeySignature, }; server.joinWallet(copayerOpts, function(err) { should.not.exist(err); @@ -418,7 +378,7 @@ describe('Copay server', function() { var copayerOpts = { walletId: walletId, name: 'me', - xPubKey: someXPubKeys[0], + xPubKey: TestData.copayers[0].xPubKey, xPubKeySignature: 'bad sign', }; server.joinWallet(copayerOpts, function(err) { @@ -431,7 +391,7 @@ describe('Copay server', function() { var copayerOpts = { walletId: walletId, name: 'me', - xPubKey: someXPubKeys[0], + xPubKey: TestData.copayers[0].xPubKey[0], }; server.joinWallet(copayerOpts, function(err) { err.should.exist; @@ -444,8 +404,8 @@ describe('Copay server', function() { var copayerOpts = { walletId: walletId, name: 'me', - xPubKey: someXPubKeys[0], - xPubKeySignature: someXPubKeysSignatures[1], + xPubKey: TestData.copayers[0].xPubKey, + xPubKeySignature: TestData.copayers[1].xPubKeySignature, }; server.joinWallet(copayerOpts, function(err) { err.message.should.equal('Bad request'); @@ -478,8 +438,8 @@ describe('Copay server', function() { it('should successfully verify message signature', function(done) { var opts = { - message: aText, - signature: aTextSignature, + message: TestData.message.text, + signature: TestData.message.signature, }; server.verifyMessageSignature(opts, function(err, isValid) { should.not.exist(err); @@ -490,8 +450,8 @@ describe('Copay server', function() { it('should fail to verify message signature for different copayer', function(done) { var opts = { - message: aText, - signature: aTextSignature, + message: TestData.message.text, + signature: TestData.message.signature, }; helpers.getAuthServer(wallet.copayers[1].id, function(server) { server.verifyMessageSignature(opts, function(err, isValid) { @@ -517,7 +477,7 @@ describe('Copay server', function() { server.createAddress({}, function(err, address) { should.not.exist(err); address.should.exist; - address.address.should.equal('36JdLEUDa6UwCfMhhkdZ2VFnDrGUoLedsR'); + address.address.should.equal('38Jf1QE7ddXscW76ACgJrNkMWBwDAgMm6M'); address.path.should.equal('m/2147483647/0/0'); done(); }); @@ -529,15 +489,15 @@ describe('Copay server', function() { name: 'my wallet', m: 2, n: 3, - pubKey: keyPair.pub, + pubKey: TestData.keyPair.pub, }; server.createWallet(walletOpts, function(err, walletId) { should.not.exist(err); var copayerOpts = { walletId: walletId, name: 'me', - xPubKey: aXPubKey, - xPubKeySignature: aXPubKeySignature, + xPubKey: TestData.copayers[0].xPubKey, + xPubKeySignature: TestData.copayers[0].xPubKeySignature, }; server.joinWallet(copayerOpts, function(err, copayerId) { should.not.exist(err); @@ -581,7 +541,7 @@ describe('Copay server', function() { server.createAddress({}, function(err, address) { should.not.exist(err); address.should.exist; - address.address.should.equal('36JdLEUDa6UwCfMhhkdZ2VFnDrGUoLedsR'); + address.address.should.equal('38Jf1QE7ddXscW76ACgJrNkMWBwDAgMm6M'); address.path.should.equal('m/2147483647/0/0'); done(); }); @@ -591,18 +551,19 @@ describe('Copay server', function() { }); describe('#createTx', function() { - var server, wallet; + var server, wallet, copayerPriv; beforeEach(function(done) { - helpers.createAndJoinWallet(2, 2, function(s, w) { + helpers.createAndJoinWallet(2, 2, function(s, w, c) { server = s; wallet = w; + copayerPriv = c; server.createAddress({}, function(err, address) { done(); }); }); }); - it.only('should create a tx', function(done) { + it('should create a tx', function(done) { helpers.createUtxos(server, wallet, helpers.toSatoshi([100, 200]), function(utxos) { helpers.stubBlockExplorer(server, utxos); var txOpts = { @@ -610,10 +571,9 @@ describe('Copay server', function() { amount: helpers.toSatoshi(80), message: 'some message', }; - helpers.addProposalSignature(txOpts, ); - console.log(txOpts); + helpers.addProposalSignature(txOpts, copayerPriv[0].privKey); + server.createTx(txOpts, function(err, tx) { - console.log(err); should.not.exist(err); tx.should.exist; tx.message.should.equal('some message'); @@ -639,15 +599,15 @@ describe('Copay server', function() { name: 'my wallet', m: 2, n: 3, - pubKey: keyPair.pub, + pubKey: TestData.keyPair.pub, }; server.createWallet(walletOpts, function(err, walletId) { should.not.exist(err); var copayerOpts = { walletId: walletId, name: 'me', - xPubKey: aXPubKey, - xPubKeySignature: aXPubKeySignature, + xPubKey: TestData.copayers[0].xPubKey, + xPubKeySignature: TestData.copayers[0].xPubKeySignature, }; server.joinWallet(copayerOpts, function(err, copayerId) { should.not.exist(err); @@ -655,8 +615,8 @@ describe('Copay server', function() { var txOpts = { toAddress: '18PzpUFkFZE8zKWUPvfykkTxmB9oMR8qP7', amount: helpers.toSatoshi(80), - proposalSignature: 'dummy', }; + helpers.addProposalSignature(txOpts, copayerPriv[0].privKey); server.createTx(txOpts, function(err, tx) { should.not.exist(tx); err.should.exist; @@ -674,8 +634,8 @@ describe('Copay server', function() { var txOpts = { toAddress: 'invalid address', amount: helpers.toSatoshi(80), - proposalSignature: 'dummy', }; + helpers.addProposalSignature(txOpts, copayerPriv[0].privKey); server.createTx(txOpts, function(err, tx) { should.not.exist(tx); @@ -693,8 +653,8 @@ describe('Copay server', function() { var txOpts = { toAddress: 'myE38JHdxmQcTJGP1ZiX4BiGhDxMJDvLJD', // testnet amount: helpers.toSatoshi(80), - proposalSignature: 'dummy', }; + helpers.addProposalSignature(txOpts, copayerPriv[0].privKey); server.createTx(txOpts, function(err, tx) { should.not.exist(tx); @@ -712,8 +672,8 @@ describe('Copay server', function() { var txOpts = { toAddress: '18PzpUFkFZE8zKWUPvfykkTxmB9oMR8qP7', amount: helpers.toSatoshi(120), - proposalSignature: 'dummy', }; + helpers.addProposalSignature(txOpts, copayerPriv[0].privKey); server.createTx(txOpts, function(err, tx) { err.code.should.equal('INSUFFICIENTFUNDS'); @@ -742,8 +702,8 @@ describe('Copay server', function() { var txOpts = { toAddress: '18PzpUFkFZE8zKWUPvfykkTxmB9oMR8qP7', amount: helpers.toSatoshi(12), - proposalSignature: 'dummy', }; + helpers.addProposalSignature(txOpts, copayerPriv[0].privKey); server.createTx(txOpts, function(err, tx) { should.not.exist(err); tx.should.exist; @@ -751,8 +711,8 @@ describe('Copay server', function() { var txOpts2 = { toAddress: '18PzpUFkFZE8zKWUPvfykkTxmB9oMR8qP7', amount: 8, - proposalSignature: 'dummy', }; + helpers.addProposalSignature(txOpts2, copayerPriv[0].privKey); server.createTx(txOpts2, function(err, tx) { should.not.exist(err); tx.should.exist; @@ -777,8 +737,8 @@ describe('Copay server', function() { var txOpts = { toAddress: '18PzpUFkFZE8zKWUPvfykkTxmB9oMR8qP7', amount: helpers.toSatoshi(12), - proposalSignature: 'dummy', }; + helpers.addProposalSignature(txOpts, copayerPriv[0].privKey); server.createTx(txOpts, function(err, tx) { should.not.exist(err); tx.should.exist; @@ -786,8 +746,8 @@ describe('Copay server', function() { var txOpts2 = { toAddress: '18PzpUFkFZE8zKWUPvfykkTxmB9oMR8qP7', amount: helpers.toSatoshi(24), - proposalSignature: 'dummy', }; + helpers.addProposalSignature(txOpts2, copayerPriv[0].privKey); server.createTx(txOpts2, function(err, tx) { err.code.should.equal('INSUFFICIENTFUNDS'); err.message.should.equal('Insufficient funds'); @@ -821,8 +781,8 @@ describe('Copay server', function() { var txOpts = { toAddress: '18PzpUFkFZE8zKWUPvfykkTxmB9oMR8qP7', amount: helpers.toSatoshi(80), - proposalSignature: 'dummy', }; + helpers.addProposalSignature(txOpts, copayerPriv[0].privKey); async.map(_.range(N), function(i, cb) { server.createTx(txOpts, function(err, tx) { cb(err, tx); @@ -846,20 +806,21 @@ describe('Copay server', function() { }); describe('#signTx', function() { - var server, wallet, txid; + var server, wallet, copayerPriv, txid; beforeEach(function(done) { - helpers.createAndJoinWallet(2, 2, function(s, w) { + helpers.createAndJoinWallet(2, 2, function(s, w, c) { server = s; wallet = w; + copayerPriv = c; server.createAddress({}, function(err, address) { helpers.createUtxos(server, wallet, helpers.toSatoshi([1, 2, 3, 4, 5, 6, 7, 8]), function(utxos) { helpers.stubBlockExplorer(server, utxos); var txOpts = { toAddress: '18PzpUFkFZE8zKWUPvfykkTxmB9oMR8qP7', amount: helpers.toSatoshi(10), - proposalSignature: 'dummy', }; + helpers.addProposalSignature(txOpts, copayerPriv[0].privKey); server.createTx(txOpts, function(err, tx) { should.not.exist(err); tx.should.exist; @@ -876,7 +837,7 @@ describe('Copay server', function() { var tx = txs[0]; tx.id.should.equal(txid); - var signatures = helpers.clientSign(tx, someXPrivKey[0], wallet.n); + var signatures = helpers.clientSign(tx, TestData.copayers[0].xPrivKey, wallet.n); server.signTx({ txProposalId: txid, signatures: signatures, @@ -892,7 +853,7 @@ describe('Copay server', function() { var tx = txs[0]; tx.id.should.equal(txid); - var signatures = helpers.clientSign(tx, someXPrivKey[0], wallet.n); + var signatures = helpers.clientSign(tx, TestData.copayers[0].xPrivKey, wallet.n); signatures[0] = 1; server.signTx({ @@ -923,11 +884,12 @@ describe('Copay server', function() { describe('#signTx and broadcast', function() { - var server, wallet, utxos; + var server, wallet, copayerPriv, utxos; beforeEach(function(done) { - helpers.createAndJoinWallet(1, 1, function(s, w) { + helpers.createAndJoinWallet(1, 1, function(s, w, c) { server = s; wallet = w; + copayerPriv = c; server.createAddress({}, function(err, address) { helpers.createUtxos(server, wallet, helpers.toSatoshi([1, 2, 3, 4, 5, 6, 7, 8]), function(inutxos) { utxos = inutxos; @@ -943,6 +905,7 @@ describe('Copay server', function() { toAddress: '18PzpUFkFZE8zKWUPvfykkTxmB9oMR8qP7', amount: helpers.toSatoshi(10), }; + helpers.addProposalSignature(txOpts, copayerPriv[0].privKey); server.createTx(txOpts, function(err, txp) { should.not.exist(err); txp.should.exist; @@ -951,7 +914,7 @@ describe('Copay server', function() { server.getPendingTxs({}, function(err, txps) { var txp = txps[0]; txp.id.should.equal(txpid); - var signatures = helpers.clientSign(txp, someXPrivKey[0], wallet.n); + var signatures = helpers.clientSign(txp, TestData.copayers[0].xPrivKey, wallet.n); server.signTx({ txProposalId: txpid, signatures: signatures, @@ -972,6 +935,7 @@ describe('Copay server', function() { toAddress: '18PzpUFkFZE8zKWUPvfykkTxmB9oMR8qP7', amount: helpers.toSatoshi(10), }; + helpers.addProposalSignature(txOpts, copayerPriv[0].privKey); server.createTx(txOpts, function(err, txp) { should.not.exist(err); txp.should.exist; @@ -980,7 +944,7 @@ describe('Copay server', function() { server.getPendingTxs({}, function(err, txps) { var txp = txps[0]; txp.id.should.equal(txpid); - var signatures = helpers.clientSign(txp, someXPrivKey[0], wallet.n); + var signatures = helpers.clientSign(txp, TestData.copayers[0].xPrivKey, wallet.n); server.signTx({ txProposalId: txpid, signatures: signatures, @@ -1002,11 +966,12 @@ describe('Copay server', function() { }); describe('Tx proposal workflow', function() { - var server, wallet, utxos; + var server, wallet, copayerPriv, utxos; beforeEach(function(done) { - helpers.createAndJoinWallet(2, 3, function(s, w) { + helpers.createAndJoinWallet(2, 3, function(s, w, c) { server = s; wallet = w; + copayerPriv = c; server.createAddress({}, function(err, address) { helpers.createUtxos(server, wallet, helpers.toSatoshi([1, 2, 3, 4, 5, 6, 7, 8]), function(inutxos) { utxos = inutxos; @@ -1022,8 +987,8 @@ describe('Copay server', function() { toAddress: '18PzpUFkFZE8zKWUPvfykkTxmB9oMR8qP7', amount: helpers.toSatoshi(10), message: 'some message', - proposalSignature: 'dummy', }; + helpers.addProposalSignature(txOpts, copayerPriv[0].privKey); server.createTx(txOpts, function(err, txp) { should.not.exist(err); should.exist.txp; @@ -1049,7 +1014,7 @@ describe('Copay server', function() { }); describe('#getTxs', function() { - var server, wallet, clock; + var server, wallet, copayerPriv, clock; beforeEach(function(done) { if (server) @@ -1058,9 +1023,10 @@ describe('Copay server', function() { this.timeout(5000); console.log('\tCreating TXS...'); clock = sinon.useFakeTimers(); - helpers.createAndJoinWallet(1, 1, function(s, w) { + helpers.createAndJoinWallet(1, 1, function(s, w, c) { server = s; wallet = w; + copayerPriv = c; server.createAddress({}, function(err, address) { helpers.createUtxos(server, wallet, helpers.toSatoshi(_.range(10)), function(utxos) { helpers.stubBlockExplorer(server, utxos); @@ -1068,6 +1034,7 @@ describe('Copay server', function() { toAddress: '18PzpUFkFZE8zKWUPvfykkTxmB9oMR8qP7', amount: helpers.toSatoshi(0.1), }; + helpers.addProposalSignature(txOpts, copayerPriv[0].privKey); async.eachSeries(_.range(10), function(i, next) { clock.tick(10000); server.createTx(txOpts, function(err, tx) { diff --git a/test/testdata.js b/test/testdata.js new file mode 100644 index 0000000..6bc36b1 --- /dev/null +++ b/test/testdata.js @@ -0,0 +1,76 @@ +var keyPair = { + priv: '0dea92f1df6675085b5cdd965487bb862f84f2755bcb56fa45dbf5b387a6c4a0', + pub: '026092daeed8ecb2212869395770e956ffc9bf453f803e700f64ffa70c97a00d80', +}; + +var message = { + text: 'hello world', + signature: '3045022100addd20e5413865d65d561ad2979f2289a40d52594b1f804840babd9a63e4ebbf02204b86285e1fcab02df772e7a1325fc4b511ecad79a8f80a2bd1ad8bfa858ac3d4', // with 5c0e043a513032907d181325a8e7990b076c0af15ed13dc5e611cda9bb3ae52a +}; + +var copayers = [{ + xPrivKey: 'xprv9s21ZrQH143K2rMHbXTJmWTuFx6ssqn1vyRoZqPkCXYchBSkp5ey8kMJe84sxfXq5uChWH4gk94rWbXZt2opN9kg4ufKGvUM7HQSLjnoh7e', + xPubKey: 'xpub661MyMwAqRbcFLRkhYzK8eQdoywNHJVsJCMQNDoMks5bZymuMcyDgYfnVQYq2Q9npnVmdTAthYGc3N3uxm5sEdnTpSqBc4YYTAhNnoSxCm9', + xPubKeySignature: '30440220192ae7345d980f45f908bd63ccad60ce04270d07b91f1a9d92424a07a38af85202201591f0f71dd4e79d9206d2306862e6b8375e13a62c193953d768e884b6fb5a46', // signed using keyPair.priv + privKey: '5c0e043a513032907d181325a8e7990b076c0af15ed13dc5e611cda9bb3ae52a', // derived with 'm/1/0' + pubKey: '03814ac7decf64321a3c6967bfb746112fdb5b583531cd512cc3787eaf578947dc', +}, { + xPrivKey: 'xprv9s21ZrQH143K2JgXh8Va3Taq22D2gXw2nYULffV5dc9acQvAmB3KhomPKGwV9AbVsBcAXMW2QxCnvmHU1rVtHRfZwTxdEEAN5ZojRYdryQ1', + xPubKey: 'xpub661MyMwAqRbcEnkzoA2aQbXZa43X5zet9mPwU3thBwgZVDFKJiMaFc5sAYS97qVtMxpvceittobtoH2JKmpweSN1CLSe91hiE1Wrf5YJhsQ', + xPubKeySignature: '3045022100b9079d0d9b70da828b0e9c776fe01c5c13fc254a314c0b09a638c8695ec9360c022079922950779080569163c692ed8ee882f9ef37e7b2dff03de9c6756e7599960e', + privKey: '7708f0b7a60da9b88893e41eb2f59acf13ddc38edd794e1af9c2b57d35e99d85', + pubKey: '0266efb3b02973233636b153296486cdbc1728e1f42a1062f030af193ab14e1321', +}, { + xPrivKey: 'xprv9s21ZrQH143K2DoxHNrecLmp121HU4nZRB57jj2cGmSkp9Wrgz2AevFT98AcYocYXEyyWDwC1JUn13beDjQU87FwfCaHiWhgoSx9G31tmDa', + xPubKey: 'xpub661MyMwAqRbcEhtRPQPeyUiYZ3qmsXWQnPziY7SDq6yjgwr1EXLRCiZvzQsfnQehH8hBzCxNPYCJXx51QKcbervpkBK931H1A9F39z5E1XD', + xPubKeySignature: '3045022100ed04aca131acf6f030018a7e3dd564788bbad5528e9edb7880f032ae6917bf10022022879ca8a60700c9c3bf9d603ae2555d4be1914084c912579b4bc09a432e9c32', + privKey: 'a8e36ab9e065a5cc0551938c225d40542b7780a84aff55cb52e4eb4d7f64de11', + pubKey: '033e44b94789a591380787effbad0a01f41aedd7ed315c931efc51284e99ae34a9', +}, { + xPrivKey: 'xprv9s21ZrQH143K3dHn6j7zuLSnnMpBAceHfQFDm6R3wbkD26pTSUuZ7JY4549T8mMhwwUeq6SW6guDwy6cUhqs6PwoF2svKKkLjJdeKi1BzUn', + xPubKey: 'xpub661MyMwAqRbcG7NFCkf1GUPXLPefa5N92dApZUpfVwHBtu9bz2Dof6rXvKjioVpLXRBHKeyX2AxLdtaCbUtz2zx3dE9F4mPkDsARrPaGsSL', + xPubKeySignature: '3045022100a17dee46810e379aa37104ec1a4e20276aa41eac67b7e555475b15db6f6ee8ca0220472d114368f6d78bd8dba5c5fed77b22437341621d7879331bc48f7ee7701853', + privKey: '68cc2c1776f3456fcdef12812e634b6adbd676c5b8168a4b2547cf73c5363cfd', + pubKey: '027597e3a18c829dfdd92f875ae87f2aa4654cbb13db28a92a19401cf6f8ac18cb', +}, { + xPrivKey: 'xprv9s21ZrQH143K3Wac3NKJ8nZsBsn4HboPtCD2LDB8zkXcmo9q97efAi9i6KkcyBoJ4vjD59corGsdJebmNXud4nH3bCBSo64uWfwauo3Kdco', + xPubKey: 'xpub661MyMwAqRbcFzf59PrJVvWbjucYh4XFFR8d8bakZ64bebUygexuiWUBwa7EnFosoFstoocLQTrLPeAQThonSrYTDQ18gkS219dLJuwUHDb', + xPubKeySignature: '30440220023c1902434aaca0c2ed3c92262d56ee4296cd5c7598b009b8556deab2df89e70220714117970debf5cc1232441aa2d1ce335b5b99958acb2d000c4241e2a2fc567f', + privKey: 'fc97d94e97857b2016a1e68ab0313ce2ea5a791638e8eb0bb6d5a5aa72de01df', + pubKey: '03a3e04a3fb218b074306ca2a4995ec1ea97ef2b73dd54edfbae9ee56651dd21cc', +}, { + xPrivKey: 'xprv9s21ZrQH143K2Hxh1Xj59WjAimbDuubNBFknLYPr563BBziVuLhMvw7F3CkYMYj1y6QSbDnKQVHrMGekXi7awjLwKR1XWcMoR3eKEcH65Pa', + xPubKey: 'xpub661MyMwAqRbcEn3A7ZG5WefuGoRiKNKDYUgP8voTdRaA4o3eSt1cUjRitVc75a2gsifRDufbicYXeQCchDvkRKSSTWi1uy7PPaNHnerGvTa', + xPubKeySignature: '3044022042f063cd154a359f1d49202d79efc0737c47077ee50e36ed3d796327b9b29a9602206a4baf2902b49d1cb265eb31b9ab12d470fd023a11d9d425679a1630ba0b0e29', + privKey: '72381546174e6165e39853510bf3353645cb2e19e0499d3bb1d8aef0027352eb', + pubKey: '037e4163f69c3e2b05e980e3ac5dac06730894b1ba520a15a9d8221245d4bfe2a4', +}, { + xPrivKey: 'xprv9s21ZrQH143K2L2wxVQ5nJ8FrTjz2KHB4wy83Xu6y6jdxmzrKNWvh6g7apPJqwj5NjhrmyJ6TYe9Hk4fbYx4tRg7Zk4Y7dAdgej4RVeUBTn', + xPubKey: 'xpub661MyMwAqRbcEp7R4Ww69S4zQVaURn12SAtiqvJiXSGcqaKzruqBEtzbS97V145KiYxsW4g9M3pqsibfc5mtbMn4R52v7bnnrHGAoiHb1pz', + xPubKeySignature: '304402207b082a63fc39b90a0f18edeb20d191430f11a9e5378681f15a68aac052aa858202201fd127b374e4a301a45f0c73d2a747d156a60075e643308e489a672bd0a7b4fb', + privKey: 'daff48eab1268c23e9ecde993b93ace4a375e7c627da0d3662746c7e3fecbdfa', + pubKey: '02035c09deeef7436df39a09ef2167129c686c6177185216525b9d778af96bacd7', +}, { + xPrivKey: 'xprv9s21ZrQH143K3Pqe7LhTkE84VM6GysvSvggfhS3KbHvgBLaaQeR9YNePRo3vpLMVBv5SNhNVAaEDyj6Q8vMRVYM4X9bWYCiPgsJXkH8WzX1', + xPubKey: 'xpub661MyMwAqRbcFLRkhYzK8eQdoywNHJVsJCMQNDoMks5bZymuMcyDgYfnVQYq2Q9npnVmdTAthYGc3N3uxm5sEdnTpSqBc4YYTAhNnoSxCm9', + xPubKeySignature: '30440220192ae7345d980f45f908bd63ccad60ce04270d07b91f1a9d92424a07a38af85202201591f0f71dd4e79d9206d2306862e6b8375e13a62c193953d768e884b6fb5a46', + privKey: '5c0e043a513032907d181325a8e7990b076c0af15ed13dc5e611cda9bb3ae52a', + pubKey: '03814ac7decf64321a3c6967bfb746112fdb5b583531cd512cc3787eaf578947dc', +}, { + xPrivKey: 'xprv9s21ZrQH143K2QSAHGxQhUsJYFDcZ6h2oiTjKFPmbnzeNzXgRW73NwX7ifBgbJ35eHGR7toyj9CCXB6Wzf5iCjj3YDuJuvBoJFJsiQAdTUH', + xPubKey: 'xpub661MyMwAqRbcEtWdPJVR4cp36H46xZQtAwPL7doPA8XdFnrpy3RHvjqbZxERYNMd4E2tt84xy4F2PqtKkHFDzZbSAaUabp36oZDwwPEqFjK', + xPubKeySignature: '304502210081a88684d4e27cab752d0df6a746aeb4bbcac57e73edd3847ffb43f1cf6740b20220312598f47dc5e775ea2ba97048764675afa4796173115049b4dacc8882b5c7b7', + privKey: '01273975489d85ac06f2e47677149420cd4901264cb40e3a756ff901acfc11f6', + pubKey: '0210eed257f41c9a991f8bd9523f66c3a83c1aab27cd2ccf233f8f5c3caef77e7a', +}, { + xPrivKey: 'xprv9s21ZrQH143K2bj7Azs1rCkumDJmbNveDA96wDJThzsDEJjBngkFXEr646AbvrTAfRd2scqq7hN48fGXesobx4sKRkddCrLaCpoWUkMJErj', + xPubKey: 'xpub661MyMwAqRbcF5oaH2Q2DLheKF9FzqeVaP4hjbi5GLQC774LLE4W53AZuMztQ6e6SMmEMj8K8zsP3iMMnJgK2PawWZCh7QcdgAg7eJWSJFr', + xPubKeySignature: '304402207781231f8bd9a679938057373702afdeec43e84b5b239e2e4dc8e35c63e4ee7102207f7ed929c81dfb59ebd14f56609dcd8255de6337c967704340a2089080fd896f', + privKey: 'dda3b5d7c6a9294a71b3ae116e69be756bed55f1caf68205e7889baa5fc76dd6', + pubKey: '03182e14c3d256359ba478d3c7842ad882141f0e61ef905dcb6b5c9786f958f325', +}, ]; + + +module.exports.keyPair = keyPair; +module.exports.message = message; +module.exports.copayers = copayers;