add test for parsing list of signatures

This commit is contained in:
Ruben de Vries 2015-10-30 17:07:04 +01:00
parent 6e1e4e69c4
commit f9d9fa0622
1 changed files with 66 additions and 2 deletions

View File

@ -31,8 +31,8 @@ describe('MultiSigInput', function() {
};
it('can count missing signatures', function() {
var transaction = new Transaction()
.from(output, [public1, public2, public3], 2)
.to(address, 1000000);
.from(output, [public1, public2, public3], 2)
.to(address, 1000000);
var input = transaction.inputs[0];
input.countSignatures().should.equal(0);
@ -47,6 +47,24 @@ describe('MultiSigInput', function() {
input.countMissingSignatures().should.equal(0);
input.isFullySigned().should.equal(true);
});
it('can count missing signatures, signed with key 3 and 1', function() {
var transaction = new Transaction()
.from(output, [public1, public2, public3], 2)
.to(address, 1000000);
var input = transaction.inputs[0];
input.countSignatures().should.equal(0);
transaction.sign(privateKey3);
input.countSignatures().should.equal(1);
input.countMissingSignatures().should.equal(1);
input.isFullySigned().should.equal(false);
transaction.sign(privateKey1);
input.countSignatures().should.equal(2);
input.countMissingSignatures().should.equal(0);
input.isFullySigned().should.equal(true);
});
it('returns a list of public keys with missing signatures', function() {
var transaction = new Transaction()
.from(output, [public1, public2, public3], 2)
@ -110,4 +128,50 @@ describe('MultiSigInput', function() {
var roundtrip = new MultiSigInput(input.toObject());
roundtrip.toObject().should.deep.equal(input.toObject());
});
it('can parse list of signature buffers, from TX signed with key 1 and 2', function() {
var transaction = new Transaction("010000000140c1ae9d6933e4a08594f814ba73a4e94d19c8a83f45784b1684b3a3f84ee666000000009200473044022012bd2f15e56ab1b63d5ee23e194ed995ad4b81a21bcb8e0d913e5e791c07f7280220278bdb6b54cdc608193c869affe28dc2f700902218122770faff25c56142102b01483045022100e74e9955e042aca36f4f3ad907a0926c5b85e5d9608b0678a78a9cbc0259c7a2022053ff761e5f9a80558db7023e45c4979ac3c19a423f0184fb0596d3da308cc4b501ffffffff0140420f000000000017a91419438da7d16709643be5abd8df62ca4034a489a78700000000");
var inputObj = transaction.inputs[0].toObject();
inputObj.output = output;
transaction.inputs[0] = new Transaction.Input(inputObj);
inputObj.signatures = MultiSigInput.normalizeSignatures(
transaction,
transaction.inputs[0],
0,
transaction.inputs[0].script.chunks.slice(1).map(function(s) { return s.buf; }),
[public1, public2, public3]
);
transaction.inputs[0] = new MultiSigInput(inputObj, [public1, public2, public3], 2);
transaction.inputs[0].signatures[0].publicKey.should.deep.equal(public1);
transaction.inputs[0].signatures[1].publicKey.should.deep.equal(public2);
should.equal(transaction.inputs[0].signatures[2], undefined);
transaction.inputs[0].isValidSignature(transaction, transaction.inputs[0].signatures[0]).should.be.true;
transaction.inputs[0].isValidSignature(transaction, transaction.inputs[0].signatures[1]).should.be.true;
});
it('can parse list of signature buffers, from TX signed with key 3 and 1', function() {
var transaction = new Transaction("010000000140c1ae9d6933e4a08594f814ba73a4e94d19c8a83f45784b1684b3a3f84ee666000000009300483045022100fc39ce4f51b2766ec8e978296e0594ea4578a3eb2543722fd4053e92bf16e6b1022030f739868397a881b019508b9c725a5c69a3652cb8928027748e93e67dfaef5501483045022100e74e9955e042aca36f4f3ad907a0926c5b85e5d9608b0678a78a9cbc0259c7a2022053ff761e5f9a80558db7023e45c4979ac3c19a423f0184fb0596d3da308cc4b501ffffffff0140420f000000000017a91419438da7d16709643be5abd8df62ca4034a489a78700000000");
var inputObj = transaction.inputs[0].toObject();
inputObj.output = output;
transaction.inputs[0] = new Transaction.Input(inputObj);
inputObj.signatures = MultiSigInput.normalizeSignatures(
transaction,
transaction.inputs[0],
0,
transaction.inputs[0].script.chunks.slice(1).map(function(s) { return s.buf; }),
[public1, public2, public3]
);
transaction.inputs[0] = new MultiSigInput(inputObj, [public1, public2, public3], 2);
transaction.inputs[0].signatures[0].publicKey.should.deep.equal(public1);
should.equal(transaction.inputs[0].signatures[1], undefined);
transaction.inputs[0].signatures[2].publicKey.should.deep.equal(public3);
transaction.inputs[0].isValidSignature(transaction, transaction.inputs[0].signatures[0]).should.be.true;
transaction.inputs[0].isValidSignature(transaction, transaction.inputs[0].signatures[2]).should.be.true;
});
});