fcoin/test/input-test.js
2017-09-20 22:33:25 +04:00

172 lines
5.0 KiB
JavaScript

/* eslint-env mocha */
/* eslint prefer-arrow-callback: "off" */
'use strict';
const Input = require('../lib/primitives/input');
const assert = require('./util/assert');
const common = require('./util/common');
// Take input rawbytes from the raw data format
const tx1 = common.readTX('tx1');
const input1 = tx1.getRaw().slice(5, 154);
// Take input rawbytes from the raw data format
const tx2 = common.readTX('tx3');
const input2 = tx2.getRaw().slice(152, 339);
// Take input rawbytes from the raw data format
const tx3 = common.readTX('tx4');
const input3 = tx3.getRaw().slice(5, 266);
describe('Input', function() {
it('should return same raw', () => {
[input1, input2, input3].forEach((rawinput) => {
const raw = rawinput.slice();
const input = Input.fromRaw(raw);
assert.bufferEqual(raw, input.toRaw());
});
});
it('should parse p2pkh input', () => {
const raw = input1.slice();
const rawprevout = raw.slice(0, 36);
const rawscript = raw.slice(37, 145);
const input = Input.fromRaw(raw);
const type = input.getType();
const addr = input.getAddress().toBase58();
const prevout = input.prevout.toRaw();
assert.strictEqual(type, 'pubkeyhash');
assert.strictEqual(addr, '1PM9ZgAV8Z4df1md2zRTF98tPjzTAfk2a6');
assert.strictEqual(input.isFinal(), true);
assert.strictEqual(input.isRBF(), false);
assert.strictEqual(input.getSize(), raw.length);
assert.bufferEqual(input.script.toRaw(), rawscript);
assert.bufferEqual(prevout, rawprevout);
});
it('should parse multisig input', () => {
const raw = input2.slice();
const rawprevout = raw.slice(0, 36);
const rawscript = raw.slice(37, 183);
const input = Input.fromRaw(raw);
const type = input.getType();
const addr = input.getAddress();
const prevout = input.prevout.toRaw();
assert.strictEqual(type, 'multisig');
assert.strictEqual(addr, null);
assert.strictEqual(input.isFinal(), true);
assert.strictEqual(input.isRBF(), false);
assert.strictEqual(input.getSize(), raw.length);
assert.bufferEqual(input.script.toRaw(), rawscript);
assert.bufferEqual(prevout, rawprevout);
});
it('should parse p2sh multisig input', () => {
const raw = input3.slice();
const rawprevout = raw.slice(0, 36);
const rawscript = raw.slice(37, 257);
const rawredeem = raw.slice(186, 257);
const input = Input.fromRaw(raw);
const type = input.getType();
const subtype = input.getSubtype();
const addr = input.getAddress().toBase58();
const prevout = input.prevout.toRaw();
const redeem = input.getRedeem().toRaw();
assert.strictEqual(type, 'scripthash');
assert.strictEqual(subtype, 'multisig');
assert.strictEqual(addr, '3416sTvfjDT8YPJ6PywJE1Pm2GgWiv2guz');
assert.strictEqual(input.isFinal(), false);
assert.strictEqual(input.isRBF(), true);
assert.strictEqual(input.getSize(), raw.length);
assert.bufferEqual(input.script.toRaw(), rawscript);
assert.bufferEqual(prevout, rawprevout);
assert.bufferEqual(redeem, rawredeem);
});
it('should parse coinbase input', () => {
const rawprevout = Buffer.from('' +
// prevout hash
'0000000000000000000000000000000000000000' +
'000000000000000000000000' +
// prevout index
'ffffffff', 'hex');
const rawscript = Buffer.from('' +
// length
'50' +
// raw script
'0332f906047b20c6582f4254432e434f4d2f42436' +
'f696e2ffabe6d6d911d3dbdeb854243e6eb04631d' +
'017fd183eb54a78e06e9e0dc22f38e765fa267010' +
'00000000000002503d49ad942020000000000', 'hex');
const sequence = Buffer.from('ffffffff', 'hex');
const raw = Buffer.alloc(40 + rawscript.length);
rawprevout.copy(raw, 0);
rawscript.copy(raw, 36);
sequence.copy(raw, raw.length - 4);
const input = Input.fromRaw(raw);
const type = input.getType();
const prevout = input.prevout.toRaw();
assert.strictEqual(type, 'coinbase');
assert.strictEqual(input.isFinal(), true);
assert.strictEqual(input.isRBF(), false);
assert.strictEqual(input.getSize(), raw.length);
assert.bufferEqual(input.script.toRaw(), rawscript.slice(1));
assert.bufferEqual(prevout, rawprevout);
});
it('should check zero signature script', () => {
const rawprevout = Buffer.from('' +
'759104b6b99f9f20d3de9e7ddbb2ac84cd8a8af2' +
'd7a6cdc46ac9fbdc0a388b3c' +
'ffffffff', 'hex');
const rawscript = Buffer.from('00', 'hex');
const sequence = Buffer.from('ffffffff', 'hex');
const raw = Buffer.alloc(41);
rawprevout.copy(raw, 0);
rawscript.copy(raw, 36);
sequence.copy(raw, raw.length - 4);
const input = Input.fromRaw(raw);
const type = input.getType();
const prevout = input.prevout.toRaw();
assert.strictEqual(type, 'nonstandard');
assert.strictEqual(input.isFinal(), true);
assert.strictEqual(input.isRBF(), false);
assert.bufferEqual(input.script.toRaw(), rawscript.slice(1));
assert.bufferEqual(prevout, rawprevout);
});
});