|
@ -94,7 +94,7 @@ helpers.toSatoshi = function(btc) { |
|
|
helpers.stubUtxos = function(server, wallet, amounts, cb) { |
|
|
helpers.stubUtxos = function(server, wallet, amounts, cb) { |
|
|
var amounts = [].concat(amounts); |
|
|
var amounts = [].concat(amounts); |
|
|
|
|
|
|
|
|
async.map(_.range(Math.ceil(amounts.length / 2)), function(i, next) { |
|
|
async.map(_.range(1, Math.ceil(amounts.length / 2) + 1), function(i, next) { |
|
|
server.createAddress({}, function(err, address) { |
|
|
server.createAddress({}, function(err, address) { |
|
|
next(err, address); |
|
|
next(err, address); |
|
|
}); |
|
|
}); |
|
@ -669,9 +669,7 @@ describe('Copay server', function() { |
|
|
helpers.createAndJoinWallet(2, 3, function(s, w) { |
|
|
helpers.createAndJoinWallet(2, 3, function(s, w) { |
|
|
server = s; |
|
|
server = s; |
|
|
wallet = w; |
|
|
wallet = w; |
|
|
server.createAddress({}, function(err, address) { |
|
|
done(); |
|
|
done(); |
|
|
|
|
|
}); |
|
|
|
|
|
}); |
|
|
}); |
|
|
}); |
|
|
}); |
|
|
|
|
|
|
|
@ -680,7 +678,7 @@ describe('Copay server', function() { |
|
|
var txOpts = helpers.createProposalOpts('18PzpUFkFZE8zKWUPvfykkTxmB9oMR8qP7', 80, 'some message', TestData.copayers[0].privKey); |
|
|
var txOpts = helpers.createProposalOpts('18PzpUFkFZE8zKWUPvfykkTxmB9oMR8qP7', 80, 'some message', TestData.copayers[0].privKey); |
|
|
server.createTx(txOpts, function(err, tx) { |
|
|
server.createTx(txOpts, function(err, tx) { |
|
|
should.not.exist(err); |
|
|
should.not.exist(err); |
|
|
tx.should.exist; |
|
|
should.exist(tx); |
|
|
tx.message.should.equal('some message'); |
|
|
tx.message.should.equal('some message'); |
|
|
tx.isAccepted().should.equal.false; |
|
|
tx.isAccepted().should.equal.false; |
|
|
tx.isRejected().should.equal.false; |
|
|
tx.isRejected().should.equal.false; |
|
@ -810,11 +808,11 @@ describe('Copay server', function() { |
|
|
var txOpts = helpers.createProposalOpts('18PzpUFkFZE8zKWUPvfykkTxmB9oMR8qP7', 12, null, TestData.copayers[0].privKey); |
|
|
var txOpts = helpers.createProposalOpts('18PzpUFkFZE8zKWUPvfykkTxmB9oMR8qP7', 12, null, TestData.copayers[0].privKey); |
|
|
server.createTx(txOpts, function(err, tx) { |
|
|
server.createTx(txOpts, function(err, tx) { |
|
|
should.not.exist(err); |
|
|
should.not.exist(err); |
|
|
tx.should.exist; |
|
|
should.exist(tx); |
|
|
var txOpts2 = helpers.createProposalOpts('18PzpUFkFZE8zKWUPvfykkTxmB9oMR8qP7', 8, null, TestData.copayers[0].privKey); |
|
|
var txOpts2 = helpers.createProposalOpts('18PzpUFkFZE8zKWUPvfykkTxmB9oMR8qP7', 8, null, TestData.copayers[0].privKey); |
|
|
server.createTx(txOpts2, function(err, tx) { |
|
|
server.createTx(txOpts2, function(err, tx) { |
|
|
should.not.exist(err); |
|
|
should.not.exist(err); |
|
|
tx.should.exist; |
|
|
should.exist(tx); |
|
|
server.getPendingTxs({}, function(err, txs) { |
|
|
server.getPendingTxs({}, function(err, txs) { |
|
|
should.not.exist(err); |
|
|
should.not.exist(err); |
|
|
txs.length.should.equal(2); |
|
|
txs.length.should.equal(2); |
|
@ -835,7 +833,7 @@ describe('Copay server', function() { |
|
|
var txOpts = helpers.createProposalOpts('18PzpUFkFZE8zKWUPvfykkTxmB9oMR8qP7', 12, null, TestData.copayers[0].privKey); |
|
|
var txOpts = helpers.createProposalOpts('18PzpUFkFZE8zKWUPvfykkTxmB9oMR8qP7', 12, null, TestData.copayers[0].privKey); |
|
|
server.createTx(txOpts, function(err, tx) { |
|
|
server.createTx(txOpts, function(err, tx) { |
|
|
should.not.exist(err); |
|
|
should.not.exist(err); |
|
|
tx.should.exist; |
|
|
should.exist(tx); |
|
|
var txOpts2 = helpers.createProposalOpts('18PzpUFkFZE8zKWUPvfykkTxmB9oMR8qP7', 24, null, TestData.copayers[0].privKey); |
|
|
var txOpts2 = helpers.createProposalOpts('18PzpUFkFZE8zKWUPvfykkTxmB9oMR8qP7', 24, null, TestData.copayers[0].privKey); |
|
|
server.createTx(txOpts2, function(err, tx) { |
|
|
server.createTx(txOpts2, function(err, tx) { |
|
|
err.code.should.equal('INSUFFICIENTFUNDS'); |
|
|
err.code.should.equal('INSUFFICIENTFUNDS'); |
|
@ -858,9 +856,7 @@ describe('Copay server', function() { |
|
|
|
|
|
|
|
|
it('should create tx using different UTXOs for simultaneous requests', function(done) { |
|
|
it('should create tx using different UTXOs for simultaneous requests', function(done) { |
|
|
var N = 5; |
|
|
var N = 5; |
|
|
helpers.stubUtxos(server, wallet, _.times(N, function() { |
|
|
helpers.stubUtxos(server, wallet, _.range(100, 100 + N, 0), function(utxos) { |
|
|
return 100; |
|
|
|
|
|
}), function(utxos) { |
|
|
|
|
|
server.getBalance({}, function(err, balance) { |
|
|
server.getBalance({}, function(err, balance) { |
|
|
should.not.exist(err); |
|
|
should.not.exist(err); |
|
|
balance.totalAmount.should.equal(helpers.toSatoshi(N * 100)); |
|
|
balance.totalAmount.should.equal(helpers.toSatoshi(N * 100)); |
|
@ -896,15 +892,13 @@ describe('Copay server', function() { |
|
|
helpers.createAndJoinWallet(2, 3, function(s, w) { |
|
|
helpers.createAndJoinWallet(2, 3, function(s, w) { |
|
|
server = s; |
|
|
server = s; |
|
|
wallet = w; |
|
|
wallet = w; |
|
|
server.createAddress({}, function(err, address) { |
|
|
helpers.stubUtxos(server, wallet, _.range(1, 9), function() { |
|
|
helpers.stubUtxos(server, wallet, _.range(1, 9), function() { |
|
|
var txOpts = helpers.createProposalOpts('18PzpUFkFZE8zKWUPvfykkTxmB9oMR8qP7', 10, null, TestData.copayers[0].privKey); |
|
|
var txOpts = helpers.createProposalOpts('18PzpUFkFZE8zKWUPvfykkTxmB9oMR8qP7', 10, null, TestData.copayers[0].privKey); |
|
|
server.createTx(txOpts, function(err, tx) { |
|
|
server.createTx(txOpts, function(err, tx) { |
|
|
should.not.exist(err); |
|
|
should.not.exist(err); |
|
|
should.exist(tx); |
|
|
tx.should.exist; |
|
|
txid = tx.id; |
|
|
txid = tx.id; |
|
|
done(); |
|
|
done(); |
|
|
|
|
|
}); |
|
|
|
|
|
}); |
|
|
}); |
|
|
}); |
|
|
}); |
|
|
}); |
|
|
}); |
|
@ -1178,11 +1172,9 @@ describe('Copay server', function() { |
|
|
helpers.createAndJoinWallet(2, 3, function(s, w) { |
|
|
helpers.createAndJoinWallet(2, 3, function(s, w) { |
|
|
server = s; |
|
|
server = s; |
|
|
wallet = w; |
|
|
wallet = w; |
|
|
server.createAddress({}, function(err, address) { |
|
|
helpers.stubUtxos(server, wallet, _.range(1, 9), function() { |
|
|
helpers.stubUtxos(server, wallet, _.range(1, 9), function() { |
|
|
helpers.stubBroadcast('999'); |
|
|
helpers.stubBroadcast('999'); |
|
|
done(); |
|
|
done(); |
|
|
|
|
|
}); |
|
|
|
|
|
}); |
|
|
}); |
|
|
}); |
|
|
}); |
|
|
}); |
|
|
}); |
|
@ -1378,17 +1370,15 @@ describe('Copay server', function() { |
|
|
helpers.createAndJoinWallet(1, 1, function(s, w) { |
|
|
helpers.createAndJoinWallet(1, 1, function(s, w) { |
|
|
server = s; |
|
|
server = s; |
|
|
wallet = w; |
|
|
wallet = w; |
|
|
server.createAddress({}, function(err, address) { |
|
|
helpers.stubUtxos(server, wallet, _.range(10), function() { |
|
|
helpers.stubUtxos(server, wallet, _.range(10), function() { |
|
|
var txOpts = helpers.createProposalOpts('18PzpUFkFZE8zKWUPvfykkTxmB9oMR8qP7', 0.1, null, TestData.copayers[0].privKey); |
|
|
var txOpts = helpers.createProposalOpts('18PzpUFkFZE8zKWUPvfykkTxmB9oMR8qP7', 0.1, null, TestData.copayers[0].privKey); |
|
|
async.eachSeries(_.range(10), function(i, next) { |
|
|
async.eachSeries(_.range(10), function(i, next) { |
|
|
clock.tick(10000); |
|
|
clock.tick(10000); |
|
|
server.createTx(txOpts, function(err, tx) { |
|
|
server.createTx(txOpts, function(err, tx) { |
|
|
next(); |
|
|
next(); |
|
|
|
|
|
}); |
|
|
|
|
|
}, function(err) { |
|
|
|
|
|
return done(err); |
|
|
|
|
|
}); |
|
|
}); |
|
|
|
|
|
}, function(err) { |
|
|
|
|
|
return done(err); |
|
|
}); |
|
|
}); |
|
|
}); |
|
|
}); |
|
|
}); |
|
|
}); |
|
@ -1464,17 +1454,15 @@ describe('Copay server', function() { |
|
|
helpers.createAndJoinWallet(1, 1, function(s, w) { |
|
|
helpers.createAndJoinWallet(1, 1, function(s, w) { |
|
|
server = s; |
|
|
server = s; |
|
|
wallet = w; |
|
|
wallet = w; |
|
|
server.createAddress({}, function(err, address) { |
|
|
helpers.stubUtxos(server, wallet, helpers.toSatoshi(_.range(4)), function() { |
|
|
helpers.stubUtxos(server, wallet, helpers.toSatoshi(_.range(4)), function() { |
|
|
var txOpts = helpers.createProposalOpts('18PzpUFkFZE8zKWUPvfykkTxmB9oMR8qP7', 0.01, null, TestData.copayers[0].privKey); |
|
|
var txOpts = helpers.createProposalOpts('18PzpUFkFZE8zKWUPvfykkTxmB9oMR8qP7', 0.01, null, TestData.copayers[0].privKey); |
|
|
async.eachSeries(_.range(3), function(i, next) { |
|
|
async.eachSeries(_.range(3), function(i, next) { |
|
|
server.createTx(txOpts, function(err, tx) { |
|
|
server.createTx(txOpts, function(err, tx) { |
|
|
should.not.exist(err); |
|
|
should.not.exist(err); |
|
|
next(); |
|
|
next(); |
|
|
|
|
|
}); |
|
|
|
|
|
}, function(err) { |
|
|
|
|
|
return done(err); |
|
|
|
|
|
}); |
|
|
}); |
|
|
|
|
|
}, function(err) { |
|
|
|
|
|
return done(err); |
|
|
}); |
|
|
}); |
|
|
}); |
|
|
}); |
|
|
}); |
|
|
}); |
|
@ -1598,18 +1586,16 @@ describe('Copay server', function() { |
|
|
server = s; |
|
|
server = s; |
|
|
wallet = w; |
|
|
wallet = w; |
|
|
|
|
|
|
|
|
server.createAddress({}, function(err, address) { |
|
|
helpers.stubUtxos(server, wallet, _.range(2), function() { |
|
|
helpers.stubUtxos(server, wallet, _.range(2), function() { |
|
|
var txOpts = { |
|
|
var txOpts = { |
|
|
toAddress: '18PzpUFkFZE8zKWUPvfykkTxmB9oMR8qP7', |
|
|
toAddress: '18PzpUFkFZE8zKWUPvfykkTxmB9oMR8qP7', |
|
|
amount: helpers.toSatoshi(0.1), |
|
|
amount: helpers.toSatoshi(0.1), |
|
|
}; |
|
|
}; |
|
|
async.eachSeries(_.range(2), function(i, next) { |
|
|
async.eachSeries(_.range(2), function(i, next) { |
|
|
server.createTx(txOpts, function(err, tx) { |
|
|
server.createTx(txOpts, function(err, tx) { |
|
|
next(); |
|
|
next(); |
|
|
}); |
|
|
}); |
|
|
}, done); |
|
|
}, done); |
|
|
|
|
|
}); |
|
|
|
|
|
}); |
|
|
}); |
|
|
}); |
|
|
}); |
|
|
}); |
|
|
}); |
|
@ -1647,27 +1633,25 @@ describe('Copay server', function() { |
|
|
server = s; |
|
|
server = s; |
|
|
wallet = w; |
|
|
wallet = w; |
|
|
|
|
|
|
|
|
server.createAddress({}, function(err, address) { |
|
|
helpers.stubUtxos(server, wallet, _.range(2), function() { |
|
|
helpers.stubUtxos(server, wallet, _.range(2), function() { |
|
|
var txOpts = { |
|
|
var txOpts = { |
|
|
toAddress: '18PzpUFkFZE8zKWUPvfykkTxmB9oMR8qP7', |
|
|
toAddress: '18PzpUFkFZE8zKWUPvfykkTxmB9oMR8qP7', |
|
|
amount: helpers.toSatoshi(0.1), |
|
|
amount: helpers.toSatoshi(0.1), |
|
|
}; |
|
|
}; |
|
|
async.eachSeries(_.range(2), function(i, next) { |
|
|
async.eachSeries(_.range(2), function(i, next) { |
|
|
server.createTx(txOpts, function(err, tx) { |
|
|
server.createTx(txOpts, function(err, tx) { |
|
|
next(); |
|
|
next(); |
|
|
}); |
|
|
}); |
|
|
}, function() { |
|
|
}, function() { |
|
|
server.removeWallet({}, function(err) { |
|
|
server.removeWallet({}, function(err) { |
|
|
db = []; |
|
|
db = []; |
|
|
server.storage._dump(function() { |
|
|
server.storage._dump(function() { |
|
|
var after = _.clone(db); |
|
|
var after = _.clone(db); |
|
|
after.should.deep.equal(before); |
|
|
after.should.deep.equal(before); |
|
|
done(); |
|
|
done(); |
|
|
}, cat); |
|
|
}, cat); |
|
|
}); |
|
|
}); |
|
|
}, cat); |
|
|
}, cat); |
|
|
|
|
|
}); |
|
|
|
|
|
}); |
|
|
}); |
|
|
}); |
|
|
}); |
|
|
}, cat); |
|
|
}, cat); |
|
@ -1763,7 +1747,7 @@ describe('Copay server', function() { |
|
|
helpers.createAndJoinWallet(1, 1, function(s, w) { |
|
|
helpers.createAndJoinWallet(1, 1, function(s, w) { |
|
|
server = s; |
|
|
server = s; |
|
|
wallet = w; |
|
|
wallet = w; |
|
|
helpers.createAddresses(server, wallet, 3, 3, function(main, change) { |
|
|
helpers.createAddresses(server, wallet, 1, 1, function(main, change) { |
|
|
mainAddresses = main; |
|
|
mainAddresses = main; |
|
|
changeAddresses = change; |
|
|
changeAddresses = change; |
|
|
done(); |
|
|
done(); |
|
@ -1867,14 +1851,14 @@ describe('Copay server', function() { |
|
|
done(); |
|
|
done(); |
|
|
}); |
|
|
}); |
|
|
}); |
|
|
}); |
|
|
it('should get tx history for outgoing txs with proposal', function(done) { |
|
|
it('should get tx history with accepted proposal', function(done) { |
|
|
server._normalizeTxHistory = sinon.stub().returnsArg(0); |
|
|
server._normalizeTxHistory = sinon.stub().returnsArg(0); |
|
|
|
|
|
|
|
|
helpers.stubUtxos(server, wallet, [100, 200], function(utxos) { |
|
|
helpers.stubUtxos(server, wallet, [100, 200], function(utxos) { |
|
|
var txOpts = helpers.createProposalOpts(mainAddresses[0].address, 80, 'some message', TestData.copayers[0].privKey); |
|
|
var txOpts = helpers.createProposalOpts(mainAddresses[0].address, 80, 'some message', TestData.copayers[0].privKey); |
|
|
server.createTx(txOpts, function(err, tx) { |
|
|
server.createTx(txOpts, function(err, tx) { |
|
|
should.not.exist(err); |
|
|
should.not.exist(err); |
|
|
tx.should.exist; |
|
|
should.exist(tx); |
|
|
|
|
|
|
|
|
helpers.stubBroadcast('1122334455'); |
|
|
helpers.stubBroadcast('1122334455'); |
|
|
var signatures = helpers.clientSign(tx, TestData.copayers[0].xPrivKey); |
|
|
var signatures = helpers.clientSign(tx, TestData.copayers[0].xPrivKey); |
|
@ -1909,7 +1893,7 @@ describe('Copay server', function() { |
|
|
var tx = txs[0]; |
|
|
var tx = txs[0]; |
|
|
tx.action.should.equal('sent'); |
|
|
tx.action.should.equal('sent'); |
|
|
tx.amount.should.equal(helpers.toSatoshi(80)); |
|
|
tx.amount.should.equal(helpers.toSatoshi(80)); |
|
|
tx.message.should.equal(tx.message); |
|
|
tx.message.should.equal('some message'); |
|
|
tx.actions.length.should.equal(1); |
|
|
tx.actions.length.should.equal(1); |
|
|
tx.actions[0].type.should.equal('accept'); |
|
|
tx.actions[0].type.should.equal('accept'); |
|
|
tx.actions[0].copayerName.should.equal('copayer 1'); |
|
|
tx.actions[0].copayerName.should.equal('copayer 1'); |
|
|