bitcore-lib
Version:
A pure and powerful JavaScript Bitcoin library.
192 lines (175 loc) • 6.66 kB
JavaScript
'use strict';
/* jshint unused: false */
var should = require('chai').should();
var expect = require('chai').expect;
var _ = require('lodash');
var bitcore = require('../../..');
var Transaction = bitcore.Transaction;
var PrivateKey = bitcore.PrivateKey;
var Address = bitcore.Address;
var Script = bitcore.Script;
var Networks = bitcore.Networks;
var Signature = bitcore.crypto.Signature;
describe('PublicKeyHashInput', function() {
var privateKey = new PrivateKey('KwF9LjRraetZuEjR8VqEq539z137LW5anYDUnVK11vM3mNMHTWb4');
var publicKey = privateKey.publicKey;
var address = new Address(publicKey, Networks.livenet);
var witnessAddress = new Address(publicKey, Networks.livenet, Address.PayToWitnessPublicKeyHash);
var wrappedAddress = new Address(publicKey, Networks.livenet, Address.PayToScriptHash);
var output = {
address: '33zbk2aSZYdNbRsMPPt6jgy6Kq1kQreqeb',
txId: '66e64ef8a3b384164b78453fa8c8194de9a473ba14f89485a0e433699daec140',
outputIndex: 0,
script: new Script(address),
satoshis: 1000000
};
var witnessOutput = {
address: 'bc1q4fyv6yjgj6kjgv5ccnfhqcv0ydft2z6h9xf0xw',
txId: '66e64ef8a3b384164b78453fa8c8194de9a473ba14f89485a0e433699daec140',
outputIndex: 0,
script: new Script(witnessAddress),
satoshis: 1000000
};
var wrappedOutput = {
address: '3PgH5AzNZpoEsdhCpwufpo6xDDHqXsAjAR',
txId: '66e64ef8a3b384164b78453fa8c8194de9a473ba14f89485a0e433699daec140',
outputIndex: 0,
script: new Script(wrappedAddress),
satoshis: 1000000
};
it('can count missing signatures', function() {
var transaction = new Transaction()
.from(output)
.to(address, 1000000);
var input = transaction.inputs[0];
input.isFullySigned().should.equal(false);
transaction.sign(privateKey);
input.isFullySigned().should.equal(true);
});
it('it\'s size can be estimated', function() {
var transaction = new Transaction()
.from(output)
.to(address, 1000000);
var input = transaction.inputs[0];
input._estimateSize().should.equal(148);
});
it('it\'s signature can be removed', function() {
var transaction = new Transaction()
.from(output)
.to(address, 1000000);
var input = transaction.inputs[0];
transaction.sign(privateKey);
input.clearSignatures();
input.isFullySigned().should.equal(false);
});
it('returns an empty array if private key mismatches', function() {
var transaction = new Transaction()
.from(output)
.to(address, 1000000);
var input = transaction.inputs[0];
var signatures = input.getSignatures(transaction, new PrivateKey(), 0);
signatures.length.should.equal(0);
});
describe('P2WPKH', function () {
it('can count missing signatures', function() {
var transaction = new Transaction()
.from(witnessOutput)
.to(address, 1000000);
var input = transaction.inputs[0];
input.isFullySigned().should.equal(false);
transaction.sign(privateKey);
input.isFullySigned().should.equal(true);
});
it('it\'s size can be estimated', function() {
var transaction = new Transaction()
.from(witnessOutput)
.to(address, 1000000);
var input = transaction.inputs[0];
input._estimateSize().should.equal(67.75);
});
it('it\'s signature can be removed', function() {
var transaction = new Transaction()
.from(witnessOutput)
.to(address, 1000000);
var input = transaction.inputs[0];
transaction.sign(privateKey);
input.clearSignatures();
input.isFullySigned().should.equal(false);
});
it('returns an empty array if private key mismatches', function() {
var transaction = new Transaction()
.from(witnessOutput)
.to(address, 1000000);
var input = transaction.inputs[0];
var signatures = input.getSignatures(transaction, new PrivateKey(), 0);
signatures.length.should.equal(0);
});
it('will get the scriptCode', function() {
var transaction = new Transaction()
.from(wrappedOutput)
.to(address, 1000000);
var input = transaction.inputs[0];
var scriptCode = input.getScriptCode(publicKey);
scriptCode.toString('hex').should.equal('1976a914aa48cd124896ad243298c4d370618f2352b50b5788ac');
});
it('will get the satoshis buffer', function() {
var transaction = new Transaction()
.from(wrappedOutput)
.to(address, 1000000);
var input = transaction.inputs[0];
var satoshisBuffer = input.getSatoshisBuffer();
satoshisBuffer.toString('hex').should.equal('40420f0000000000');
});
});
describe('P2SH-wrapped-P2WPKH', function () {
it('can count missing signatures', function() {
var transaction = new Transaction()
.from(wrappedOutput)
.to(address, 1000000);
var input = transaction.inputs[0];
input.isFullySigned().should.equal(false);
transaction.sign(privateKey);
input.isFullySigned().should.equal(true);
});
it('it\'s size can be estimated', function() {
var transaction = new Transaction()
.from(wrappedOutput)
.to(address, 1000000);
var input = transaction.inputs[0];
input._estimateSize().should.equal(90.75);
});
it('it\'s signature can be removed', function() {
var transaction = new Transaction()
.from(wrappedOutput)
.to(address, 1000000);
var input = transaction.inputs[0];
transaction.sign(privateKey);
input.clearSignatures();
input.isFullySigned().should.equal(false);
});
it('returns an empty array if private key mismatches', function() {
var transaction = new Transaction()
.from(wrappedOutput)
.to(address, 1000000);
var input = transaction.inputs[0];
var signatures = input.getSignatures(transaction, new PrivateKey(), 0);
signatures.length.should.equal(0);
});
it('will get the scriptCode', function() {
var transaction = new Transaction()
.from(wrappedOutput)
.to(address, 1000000);
var input = transaction.inputs[0];
var scriptCode = input.getScriptCode(publicKey);
scriptCode.toString('hex').should.equal('1976a914aa48cd124896ad243298c4d370618f2352b50b5788ac');
});
it('will get the satoshis buffer', function() {
var transaction = new Transaction()
.from(wrappedOutput)
.to(address, 1000000);
var input = transaction.inputs[0];
var satoshisBuffer = input.getSatoshisBuffer();
satoshisBuffer.toString('hex').should.equal('40420f0000000000');
});
});
});