|
@ -1674,6 +1674,149 @@ describe('Wallet service', function() { |
|
|
}); |
|
|
}); |
|
|
}); |
|
|
}); |
|
|
|
|
|
|
|
|
|
|
|
describe('#createTx backoff time', function() { |
|
|
|
|
|
var server, wallet, txid; |
|
|
|
|
|
|
|
|
|
|
|
beforeEach(function(done) { |
|
|
|
|
|
helpers.createAndJoinWallet(2, 2, function(s, w) { |
|
|
|
|
|
server = s; |
|
|
|
|
|
wallet = w; |
|
|
|
|
|
helpers.stubUtxos(server, wallet, _.range(1, 9), function() { |
|
|
|
|
|
var txOpts = helpers.createProposalOpts('18PzpUFkFZE8zKWUPvfykkTxmB9oMR8qP7', 10, null, TestData.copayers[0].privKey_1H_0); |
|
|
|
|
|
server.createTx(txOpts, function(err, tx) { |
|
|
|
|
|
|
|
|
|
|
|
should.not.exist(err); |
|
|
|
|
|
should.exist(tx); |
|
|
|
|
|
txid = tx.id; |
|
|
|
|
|
done(); |
|
|
|
|
|
}); |
|
|
|
|
|
}); |
|
|
|
|
|
}); |
|
|
|
|
|
}); |
|
|
|
|
|
|
|
|
|
|
|
it('should fail to create inmediatly after a rejection', function(done) { |
|
|
|
|
|
async.series([ |
|
|
|
|
|
|
|
|
|
|
|
function(next) { |
|
|
|
|
|
server.getPendingTxs({}, function(err, txs) { |
|
|
|
|
|
var tx = txs[0]; |
|
|
|
|
|
tx.id.should.equal(txid); |
|
|
|
|
|
next(); |
|
|
|
|
|
}); |
|
|
|
|
|
}, |
|
|
|
|
|
function(next) { |
|
|
|
|
|
server.rejectTx({ |
|
|
|
|
|
txProposalId: txid, |
|
|
|
|
|
reason: 'some reason', |
|
|
|
|
|
}, function(err) { |
|
|
|
|
|
should.not.exist(err); |
|
|
|
|
|
next(); |
|
|
|
|
|
}); |
|
|
|
|
|
}, |
|
|
|
|
|
function(next) { |
|
|
|
|
|
helpers.stubUtxos(server, wallet, _.range(1, 9), function() { |
|
|
|
|
|
var txOpts = helpers.createProposalOpts('18PzpUFkFZE8zKWUPvfykkTxmB9oMR8qP7', 10, null, TestData.copayers[0].privKey_1H_0); |
|
|
|
|
|
server.createTx(txOpts, function(err, tx) { |
|
|
|
|
|
err.code.should.equal('NOTALLOWEDTOCREATETX'); |
|
|
|
|
|
next(); |
|
|
|
|
|
}); |
|
|
|
|
|
}); |
|
|
|
|
|
} |
|
|
|
|
|
], done); |
|
|
|
|
|
}); |
|
|
|
|
|
|
|
|
|
|
|
it('should allow to create after backoffTime', function(done) { |
|
|
|
|
|
async.series([ |
|
|
|
|
|
|
|
|
|
|
|
function(next) { |
|
|
|
|
|
server.getPendingTxs({}, function(err, txs) { |
|
|
|
|
|
var tx = txs[0]; |
|
|
|
|
|
tx.id.should.equal(txid); |
|
|
|
|
|
next(); |
|
|
|
|
|
}); |
|
|
|
|
|
}, |
|
|
|
|
|
function(next) { |
|
|
|
|
|
server.rejectTx({ |
|
|
|
|
|
txProposalId: txid, |
|
|
|
|
|
reason: 'some reason', |
|
|
|
|
|
}, function(err) { |
|
|
|
|
|
should.not.exist(err); |
|
|
|
|
|
next(); |
|
|
|
|
|
}); |
|
|
|
|
|
}, |
|
|
|
|
|
function(next) { |
|
|
|
|
|
helpers.stubUtxos(server, wallet, _.range(1, 9), function() { |
|
|
|
|
|
var txOpts = helpers.createProposalOpts('18PzpUFkFZE8zKWUPvfykkTxmB9oMR8qP7', 10, null, TestData.copayers[0].privKey_1H_0); |
|
|
|
|
|
server.createTx(txOpts, function(err, tx) { |
|
|
|
|
|
err.code.should.equal('NOTALLOWEDTOCREATETX'); |
|
|
|
|
|
next(); |
|
|
|
|
|
}); |
|
|
|
|
|
}); |
|
|
|
|
|
}, |
|
|
|
|
|
function(next) { |
|
|
|
|
|
helpers.stubUtxos(server, wallet, _.range(1, 9), function() { |
|
|
|
|
|
var txOpts = helpers.createProposalOpts('18PzpUFkFZE8zKWUPvfykkTxmB9oMR8qP7', 10, null, TestData.copayers[0].privKey_1H_0); |
|
|
|
|
|
|
|
|
|
|
|
var clock = sinon.useFakeTimers(Date.now() + 2000 + WalletService.backoffTime * 1000); |
|
|
|
|
|
server.createTx(txOpts, function(err, tx) { |
|
|
|
|
|
should.not.exist(err); |
|
|
|
|
|
clock.restore(); |
|
|
|
|
|
next(); |
|
|
|
|
|
}); |
|
|
|
|
|
}); |
|
|
|
|
|
}, |
|
|
|
|
|
], done); |
|
|
|
|
|
}); |
|
|
|
|
|
it('should not allow to create after backoffTime and 2 rejections', function(done) { |
|
|
|
|
|
async.series([ |
|
|
|
|
|
|
|
|
|
|
|
function(next) { |
|
|
|
|
|
helpers.stubUtxos(server, wallet, _.range(1, 9), function() { |
|
|
|
|
|
var txOpts = helpers.createProposalOpts('18PzpUFkFZE8zKWUPvfykkTxmB9oMR8qP7', 10, null, TestData.copayers[0].privKey_1H_0); |
|
|
|
|
|
server.createTx(txOpts, function(err, tx) { |
|
|
|
|
|
should.not.exist(err); |
|
|
|
|
|
next(); |
|
|
|
|
|
}); |
|
|
|
|
|
}); |
|
|
|
|
|
}, |
|
|
|
|
|
function(next) { |
|
|
|
|
|
server.getPendingTxs({}, function(err, tx) { |
|
|
|
|
|
should.not.exist(err); |
|
|
|
|
|
server.rejectTx({ |
|
|
|
|
|
txProposalId: tx[0].id, |
|
|
|
|
|
reason: 'some reason', |
|
|
|
|
|
}, function(err) { |
|
|
|
|
|
should.not.exist(err); |
|
|
|
|
|
server.rejectTx({ |
|
|
|
|
|
txProposalId: tx[1].id, |
|
|
|
|
|
reason: 'some other reason', |
|
|
|
|
|
}, function(err) { |
|
|
|
|
|
should.not.exist(err); |
|
|
|
|
|
|
|
|
|
|
|
next(); |
|
|
|
|
|
}); |
|
|
|
|
|
}); |
|
|
|
|
|
}); |
|
|
|
|
|
}, |
|
|
|
|
|
function(next) { |
|
|
|
|
|
helpers.stubUtxos(server, wallet, _.range(1, 9), function() { |
|
|
|
|
|
var txOpts = helpers.createProposalOpts('18PzpUFkFZE8zKWUPvfykkTxmB9oMR8qP7', 10, null, TestData.copayers[0].privKey_1H_0); |
|
|
|
|
|
|
|
|
|
|
|
var clock = sinon.useFakeTimers(Date.now() + 2000 + WalletService.backoffTime * 1000); |
|
|
|
|
|
server.createTx(txOpts, function(err, tx) { |
|
|
|
|
|
err.code.should.equal('NOTALLOWEDTOCREATETX'); |
|
|
|
|
|
clock.restore(); |
|
|
|
|
|
next(); |
|
|
|
|
|
}); |
|
|
|
|
|
}); |
|
|
|
|
|
}, |
|
|
|
|
|
], done); |
|
|
|
|
|
}); |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
}); |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
describe('#signTx', function() { |
|
|
describe('#signTx', function() { |
|
|
var server, wallet, txid; |
|
|
var server, wallet, txid; |
|
|
|
|
|
|
|
@ -2808,7 +2951,7 @@ describe('Wallet service', function() { |
|
|
|
|
|
|
|
|
server.getPendingTxs({}, function(err, txs) { |
|
|
server.getPendingTxs({}, function(err, txs) { |
|
|
should.not.exist(err); |
|
|
should.not.exist(err); |
|
|
txs[0].deleteLockTime.should.be.above(WalletService.deleteLockTime-10); |
|
|
txs[0].deleteLockTime.should.be.above(WalletService.deleteLockTime - 10); |
|
|
|
|
|
|
|
|
var clock = sinon.useFakeTimers(Date.now() + 1 + 24 * 3600 * 1000); |
|
|
var clock = sinon.useFakeTimers(Date.now() + 1 + 24 * 3600 * 1000); |
|
|
server.removePendingTx({ |
|
|
server.removePendingTx({ |
|
@ -2833,7 +2976,7 @@ describe('Wallet service', function() { |
|
|
}, function(err) { |
|
|
}, function(err) { |
|
|
should.not.exist(err); |
|
|
should.not.exist(err); |
|
|
|
|
|
|
|
|
var clock = sinon.useFakeTimers(Date.now() + 1 + 24 * 3600 * 1000); |
|
|
var clock = sinon.useFakeTimers(Date.now() + 2000 + WalletService.deleteLockTime * 1000); |
|
|
server2.removePendingTx({ |
|
|
server2.removePendingTx({ |
|
|
txProposalId: txp.id |
|
|
txProposalId: txp.id |
|
|
}, function(err) { |
|
|
}, function(err) { |
|
|