|
@ -216,7 +216,7 @@ helpers.createAddresses = function(server, wallet, main, change, cb) { |
|
|
|
|
|
|
|
|
var storage, blockchainExplorer; |
|
|
var storage, blockchainExplorer; |
|
|
|
|
|
|
|
|
var useMongo = false; |
|
|
var useMongo = true; |
|
|
|
|
|
|
|
|
function initStorage(cb) { |
|
|
function initStorage(cb) { |
|
|
function getDb(cb) { |
|
|
function getDb(cb) { |
|
@ -1115,6 +1115,7 @@ describe('Wallet service', function() { |
|
|
should.exist(balance); |
|
|
should.exist(balance); |
|
|
balance.totalAmount.should.equal(helpers.toSatoshi(6)); |
|
|
balance.totalAmount.should.equal(helpers.toSatoshi(6)); |
|
|
balance.lockedAmount.should.equal(0); |
|
|
balance.lockedAmount.should.equal(0); |
|
|
|
|
|
balance.totalKbToSendMax.should.equal(1); |
|
|
should.exist(balance.byAddress); |
|
|
should.exist(balance.byAddress); |
|
|
balance.byAddress.length.should.equal(2); |
|
|
balance.byAddress.length.should.equal(2); |
|
|
balance.byAddress[0].amount.should.equal(helpers.toSatoshi(4)); |
|
|
balance.byAddress[0].amount.should.equal(helpers.toSatoshi(4)); |
|
@ -1134,6 +1135,7 @@ describe('Wallet service', function() { |
|
|
should.exist(balance); |
|
|
should.exist(balance); |
|
|
balance.totalAmount.should.equal(0); |
|
|
balance.totalAmount.should.equal(0); |
|
|
balance.lockedAmount.should.equal(0); |
|
|
balance.lockedAmount.should.equal(0); |
|
|
|
|
|
balance.totalKbToSendMax.should.equal(0); |
|
|
should.exist(balance.byAddress); |
|
|
should.exist(balance.byAddress); |
|
|
balance.byAddress.length.should.equal(0); |
|
|
balance.byAddress.length.should.equal(0); |
|
|
done(); |
|
|
done(); |
|
@ -1148,6 +1150,7 @@ describe('Wallet service', function() { |
|
|
should.exist(balance); |
|
|
should.exist(balance); |
|
|
balance.totalAmount.should.equal(0); |
|
|
balance.totalAmount.should.equal(0); |
|
|
balance.lockedAmount.should.equal(0); |
|
|
balance.lockedAmount.should.equal(0); |
|
|
|
|
|
balance.totalKbToSendMax.should.equal(0); |
|
|
should.exist(balance.byAddress); |
|
|
should.exist(balance.byAddress); |
|
|
balance.byAddress.length.should.equal(0); |
|
|
balance.byAddress.length.should.equal(0); |
|
|
done(); |
|
|
done(); |
|
@ -1168,6 +1171,18 @@ describe('Wallet service', function() { |
|
|
}); |
|
|
}); |
|
|
}); |
|
|
}); |
|
|
}); |
|
|
}); |
|
|
|
|
|
it('should return correct kb to send max', function(done) { |
|
|
|
|
|
helpers.stubUtxos(server, wallet, _.range(1, 10, 0), function() { |
|
|
|
|
|
server.getBalance({}, function(err, balance) { |
|
|
|
|
|
should.not.exist(err); |
|
|
|
|
|
should.exist(balance); |
|
|
|
|
|
balance.totalAmount.should.equal(helpers.toSatoshi(9)); |
|
|
|
|
|
balance.lockedAmount.should.equal(0); |
|
|
|
|
|
balance.totalKbToSendMax.should.equal(2); |
|
|
|
|
|
done(); |
|
|
|
|
|
}); |
|
|
|
|
|
}); |
|
|
|
|
|
}); |
|
|
it('should fail gracefully when blockchain is unreachable', function(done) { |
|
|
it('should fail gracefully when blockchain is unreachable', function(done) { |
|
|
blockchainExplorer.getUnspentUtxos = sinon.stub().callsArgWith(1, 'dummy error'); |
|
|
blockchainExplorer.getUnspentUtxos = sinon.stub().callsArgWith(1, 'dummy error'); |
|
|
server.createAddress({}, function(err, address) { |
|
|
server.createAddress({}, function(err, address) { |
|
@ -1618,6 +1633,56 @@ describe('Wallet service', function() { |
|
|
}); |
|
|
}); |
|
|
}); |
|
|
}); |
|
|
}); |
|
|
}); |
|
|
|
|
|
it('should be able to send max amount', function(done) { |
|
|
|
|
|
helpers.stubUtxos(server, wallet, _.range(1, 10, 0), function() { |
|
|
|
|
|
server.getBalance({}, function(err, balance) { |
|
|
|
|
|
should.not.exist(err); |
|
|
|
|
|
balance.totalAmount.should.equal(helpers.toSatoshi(9)); |
|
|
|
|
|
balance.lockedAmount.should.equal(0); |
|
|
|
|
|
balance.totalKbToSendMax.should.equal(3); |
|
|
|
|
|
var max = (balance.totalAmount - balance.lockedAmount) - (balance.totalKbToSendMax * 10000); |
|
|
|
|
|
var txOpts = helpers.createProposalOpts('18PzpUFkFZE8zKWUPvfykkTxmB9oMR8qP7', max / 1e8, null, TestData.copayers[0].privKey_1H_0); |
|
|
|
|
|
server.createTx(txOpts, function(err, tx) { |
|
|
|
|
|
should.not.exist(err); |
|
|
|
|
|
should.exist(tx); |
|
|
|
|
|
tx.amount.should.equal(max); |
|
|
|
|
|
tx.fee.should.equal(3 * 10000); |
|
|
|
|
|
server.getBalance({}, function(err, balance) { |
|
|
|
|
|
should.not.exist(err); |
|
|
|
|
|
balance.lockedAmount.should.equal(helpers.toSatoshi(9)); |
|
|
|
|
|
done(); |
|
|
|
|
|
}); |
|
|
|
|
|
}); |
|
|
|
|
|
}); |
|
|
|
|
|
}); |
|
|
|
|
|
}); |
|
|
|
|
|
it('should be able to send max non-locked amount', function(done) { |
|
|
|
|
|
helpers.stubUtxos(server, wallet, _.range(1, 10, 0), function() { |
|
|
|
|
|
var txOpts = helpers.createProposalOpts('18PzpUFkFZE8zKWUPvfykkTxmB9oMR8qP7', 3.5, null, TestData.copayers[0].privKey_1H_0); |
|
|
|
|
|
server.createTx(txOpts, function(err, tx) { |
|
|
|
|
|
should.not.exist(err); |
|
|
|
|
|
server.getBalance({}, function(err, balance) { |
|
|
|
|
|
should.not.exist(err); |
|
|
|
|
|
balance.totalAmount.should.equal(helpers.toSatoshi(9)); |
|
|
|
|
|
balance.lockedAmount.should.equal(helpers.toSatoshi(4)); |
|
|
|
|
|
balance.totalKbToSendMax.should.equal(2); |
|
|
|
|
|
var max = (balance.totalAmount - balance.lockedAmount) - (balance.totalKbToSendMax * 2000); |
|
|
|
|
|
var txOpts = helpers.createProposalOpts('18PzpUFkFZE8zKWUPvfykkTxmB9oMR8qP7', max / 1e8, null, TestData.copayers[0].privKey_1H_0, 2000); |
|
|
|
|
|
server.createTx(txOpts, function(err, tx) { |
|
|
|
|
|
should.not.exist(err); |
|
|
|
|
|
should.exist(tx); |
|
|
|
|
|
tx.amount.should.equal(max); |
|
|
|
|
|
tx.fee.should.equal(2 * 2000); |
|
|
|
|
|
server.getBalance({}, function(err, balance) { |
|
|
|
|
|
should.not.exist(err); |
|
|
|
|
|
balance.lockedAmount.should.equal(helpers.toSatoshi(9)); |
|
|
|
|
|
done(); |
|
|
|
|
|
}); |
|
|
|
|
|
}); |
|
|
|
|
|
}); |
|
|
|
|
|
}); |
|
|
|
|
|
}); |
|
|
|
|
|
}); |
|
|
}); |
|
|
}); |
|
|
|
|
|
|
|
|
describe('#createTx backoff time', function(done) { |
|
|
describe('#createTx backoff time', function(done) { |
|
|