Skip to content

Commit

Permalink
test: add some new functions to test/util/common.
Browse files Browse the repository at this point in the history
  • Loading branch information
chjj committed Aug 13, 2017
1 parent c522c79 commit 5a751d9
Show file tree
Hide file tree
Showing 9 changed files with 194 additions and 37 deletions.
2 changes: 1 addition & 1 deletion bench/buffer.js
Original file line number Diff line number Diff line change
Expand Up @@ -5,7 +5,7 @@ const StaticWriter = require('../lib/utils/staticwriter');
const common = require('../test/util/common');
const bench = require('./bench');

const {tx} = common.parseTX('data/tx5.hex');
const {tx} = common.parseTX('tx5');

{
const end = bench('serialize (static-writer)');
Expand Down
2 changes: 1 addition & 1 deletion bench/coins.js
Original file line number Diff line number Diff line change
Expand Up @@ -4,7 +4,7 @@ const Coins = require('../lib/coins/coins');
const common = require('../test/util/common');
const bench = require('./bench');

const {tx} = common.parseTX('data/tx5.hex');
const {tx} = common.parseTX('tx5');
const coins = Coins.fromTX(tx, 1);
const raw = coins.toRaw();

Expand Down
6 changes: 3 additions & 3 deletions bench/tx.js
Original file line number Diff line number Diff line change
Expand Up @@ -19,11 +19,11 @@ const undo = common.parseUndo(undoRaw);

const btx = {
tx: block.txs[397],
view: common.applyUndo(block, undo)
view: common.applyBlockUndo(block, undo)
};

const tx3 = common.parseTX('data/tx3.hex');
const tx5 = common.parseTX('data/tx5.hex');
const tx3 = common.parseTX('tx3');
const tx5 = common.parseTX('tx5');
const raw = tx5.tx.toRaw();

{
Expand Down
2 changes: 1 addition & 1 deletion scripts/dump.js
Original file line number Diff line number Diff line change
Expand Up @@ -7,7 +7,7 @@ const common = require('../test/util/common');

const SNAPSHOT = `${__dirname}/../dump.heapsnapshot`;

const {tx, view} = common.parseTX('data/tx4.hex');
const {tx, view} = common.parseTX('tx4');
const coins = Coins.fromTX(tx, 0);
const entry = MempoolEntry.fromTX(tx, view, 1000000);

Expand Down
8 changes: 4 additions & 4 deletions test/block-test.js
Original file line number Diff line number Diff line change
Expand Up @@ -139,7 +139,7 @@ describe('Block', function() {
it('should verify a historical block', () => {
const block = Block.fromRaw(block300025);
const undo = common.parseUndo(undo300025);
const view = common.applyUndo(block, undo);
const view = common.applyBlockUndo(block, undo);
const flags = Script.flags.VERIFY_P2SH | Script.flags.VERIFY_DERSIG;
const height = 300025;

Expand Down Expand Up @@ -361,7 +361,7 @@ describe('Block', function() {
it('should count sigops for block 928927 (testnet)', () => {
const block = Block.fromRaw(block928927);
const undo = common.parseUndo(undo928927);
const view = common.applyUndo(block, undo);
const view = common.applyBlockUndo(block, undo);
const flags = Script.flags.VERIFY_P2SH | Script.flags.VERIFY_WITNESS;

let sigops = 0;
Expand All @@ -375,7 +375,7 @@ describe('Block', function() {
it('should count sigops for block 928828 (testnet)', () => {
const block = Block.fromRaw(block928828);
const undo = common.parseUndo(undo928828);
const view = common.applyUndo(block, undo);
const view = common.applyBlockUndo(block, undo);
const flags = Script.flags.VERIFY_P2SH | Script.flags.VERIFY_WITNESS;

let sigops = 0;
Expand All @@ -389,7 +389,7 @@ describe('Block', function() {
it('should count sigops for block 1087400 (testnet)', () => {
const block = Block.fromRaw(block1087400);
const undo = common.parseUndo(undo1087400);
const view = common.applyUndo(block, undo);
const view = common.applyBlockUndo(block, undo);
const flags = Script.flags.VERIFY_P2SH | Script.flags.VERIFY_WITNESS;

let sigops = 0;
Expand Down
2 changes: 1 addition & 1 deletion test/coins-test.js
Original file line number Diff line number Diff line change
Expand Up @@ -13,7 +13,7 @@ const StaticWriter = require('../lib/utils/staticwriter');
const BufferReader = require('../lib/utils/reader');
const {parseTX} = require('./util/common');

const data = parseTX('data/tx1.hex');
const data = parseTX('tx1');
const tx1 = data.tx;

function reserialize(coin) {
Expand Down
21 changes: 13 additions & 8 deletions test/protocol-test.js
Original file line number Diff line number Diff line change
Expand Up @@ -15,8 +15,8 @@ const packets = require('../lib/net/packets');
const common = require('./util/common');
const network = Network.get('main');

const tx8 = common.parseTX('data/tx8.hex');
const tx9 = common.parseTX('data/tx9.hex');
const tx8 = common.parseTX('tx8');
const tx9 = common.parseTX('tx9');

describe('Protocol', function() {
const pkg = require('../lib/pkg');
Expand All @@ -28,15 +28,20 @@ describe('Protocol', function() {
framer = new Framer();
});

function packetTest(command, payload, test) {
it(`should encode/decode ${command}`, (cb) => {
const ver = Buffer.from(framer.packet(command, payload.toRaw()));
function packetTest(cmd, payload, test) {
it(`should encode/decode ${cmd}`, (cb) => {
parser.once('packet', (packet) => {
assert.strictEqual(packet.cmd, command);
test(packet);
try {
assert.strictEqual(packet.cmd, cmd);
test(packet);
} catch (e) {
cb(e);
return;
}
cb();
});
parser.feed(ver);
const raw = framer.packet(cmd, payload.toRaw());
parser.feed(raw);
});
}

Expand Down
14 changes: 7 additions & 7 deletions test/tx-test.js
Original file line number Diff line number Diff line change
Expand Up @@ -23,13 +23,13 @@ const validTests = require('./data/tx-valid.json');
const invalidTests = require('./data/tx-invalid.json');
const sighashTests = require('./data/sighash-tests.json');

const tx1 = common.parseTX('data/tx1.hex');
const tx2 = common.parseTX('data/tx2.hex');
const tx3 = common.parseTX('data/tx3.hex');
const tx4 = common.parseTX('data/tx4.hex');
const tx5 = common.parseTX('data/tx5.hex');
const tx6 = common.parseTX('data/tx6.hex');
const tx7 = common.parseTX('data/tx7.hex');
const tx1 = common.parseTX('tx1');
const tx2 = common.parseTX('tx2');
const tx3 = common.parseTX('tx3');
const tx4 = common.parseTX('tx4');
const tx5 = common.parseTX('tx5');
const tx6 = common.parseTX('tx6');
const tx7 = common.parseTX('tx7');

const MAX_SAFE_INTEGER = Number.MAX_SAFE_INTEGER;
const MAX_SAFE_ADDITION = 0xfffffffffffff;
Expand Down
174 changes: 163 additions & 11 deletions test/util/common.js
Original file line number Diff line number Diff line change
Expand Up @@ -2,22 +2,26 @@

const assert = require('assert');
const fs = require('../../lib/utils/fs');
const Block = require('../../lib/primitives/block');
const MerkleBlock = require('../../lib/primitives/merkleblock');
const {CompactBlock} = require('../../lib/net/bip152');
const TX = require('../../lib/primitives/tx');
const Output = require('../../lib/primitives/output');
const CoinView = require('../../lib/coins/coinview');
const BufferReader = require('../../lib/utils/reader');
const BufferWriter = require('../../lib/utils/writer');

exports.parseTX = function parseTX(file) {
const data = fs.readFileSync(`${__dirname}/../${file}`, 'utf8');
const parts = data.trim().split(/\n+/);
const raw = parts[0];
const tx = TX.fromRaw(raw.trim(), 'hex');
exports.parseTX = function parseTX(name) {
const data = fs.readFileSync(`${__dirname}/../data/${name}.hex`, 'utf8');
const parts = data.trim().split('\n');
const raw = Buffer.from(parts[0], 'hex');
const tx = TX.fromRaw(raw);
const view = new CoinView();
const txs = [tx];

for (let i = 1; i < parts.length; i++) {
const raw = parts[i];
const prev = TX.fromRaw(raw.trim(), 'hex');
const raw = Buffer.from(parts[i], 'hex');
const prev = TX.fromRaw(raw);
view.addTX(prev, -1);
txs.push(prev);
}
Expand All @@ -29,19 +33,87 @@ exports.parseTX = function parseTX(file) {
};
};

exports.readBlock = function readBlock(name) {
const height = name.substring(5);
const blockFile = `${__dirname}/../data/block${height}.raw`;

if (!fs.existsSync(blockFile)) {
const raw = fs.readFileSync(`${__dirname}/../data/${name}.raw`);
const block = Block.fromRaw(raw);
const view = new CoinView();
return { raw, block, view };
}

const raw = fs.readFileSync(blockFile);
const block = Block.fromRaw(raw);

const undoFile = `${__dirname}/../data/undo${height}.raw`;

if (!fs.existsSync(undoFile)) {
const view = new CoinView();
return { raw, block, view };
}

const undoRaw = fs.readFileSync(undoFile);
const undo = exports.parseUndo(undoRaw);
const view = exports.applyBlockUndo(block, undo);

return { raw, block, view };
};

exports.readMerkle = function readMerkle(name) {
const raw = fs.readFileSync(`${__dirname}/../data/${name}.raw`);
const block = MerkleBlock.fromRaw(raw);
return { raw, block };
};

exports.readCompact = function readCompact(name) {
const raw = fs.readFileSync(`${__dirname}/../data/${name}.raw`);
const block = CompactBlock.fromRaw(raw);
return { raw, block };
};

exports.readTX = function readTX(name) {
const index = name.substring(2);
const txFile = `${__dirname}/../data/tx${index}.raw`;

if (!fs.existsSync(txFile)) {
const raw = fs.readFileSync(`${__dirname}/../data/${name}.raw`);
const tx = TX.fromRaw(raw);
const view = new CoinView();
return { raw, tx, view };
}

const raw = fs.readFileSync(txFile);
const tx = TX.fromRaw(raw);

const undoFile = `${__dirname}/../data/utx${index}.raw`;

if (!fs.existsSync(undoFile)) {
const view = new CoinView();
return { raw, tx, view };
}

const undoRaw = fs.readFileSync(undoFile);
const undo = exports.parseUndo(undoRaw);
const view = exports.applyTXUndo(tx, undo);

return { raw, tx, view };
};

exports.parseUndo = function parseUndo(data) {
const br = new BufferReader(data);
const undo = [];
const items = [];

while (br.left()) {
const output = Output.fromReader(br);
undo.push(output);
items.push(output);
}

return undo;
return items;
};

exports.applyUndo = function applyUndo(block, undo) {
exports.applyBlockUndo = function applyBlockUndo(block, undo) {
const view = new CoinView();
let i = 0;

Expand All @@ -57,3 +129,83 @@ exports.applyUndo = function applyUndo(block, undo) {

return view;
};

exports.applyTXUndo = function applyTXUndo(tx, undo) {
const view = new CoinView();
let i = 0;

for (const {prevout} of tx.inputs)
view.addOutput(prevout, undo[i++]);

assert(i === undo.length, 'Undo coins data inconsistency.');

return view;
};

exports.makeBlockUndo = function makeBlockUndo(block, view) {
const items = [];

for (const tx of block.txs) {
if (tx.isCoinbase())
continue;

for (const {prevout} of tx.inputs) {
const coin = view.getOutput(prevout);
assert(coin);
items.push(coin);
}
}

return items;
};

exports.makeTXUndo = function makeTXUndo(tx, view) {
const items = [];

for (const {prevout} of tx.inputs) {
const coin = view.getOutput(prevout);
assert(coin);
items.push(coin);
}

return items;
};

exports.serializeUndo = function serializeUndo(items) {
const bw = new BufferWriter();

for (const item of items) {
bw.writeI64(item.value);
bw.writeVarBytes(item.script.toRaw());
}

return bw.render();
};

exports.writeBlock = function writeBlock(name, block, view) {
const height = name.substring(5);

fs.writeFileSync(`${__dirname}/../data/block${height}.raw`, block.toRaw());

if (!view)
return;

const undo = exports.makeBlockUndo(block, view);
const undoRaw = exports.serializeUndo(undo);

fs.writeFileSync(`${__dirname}/../data/undo${height}.raw`, undoRaw);
};

exports.writeTX = function writeTX(name, tx, view) {
const index = name.substring(2);

fs.writeFileSync(`${__dirname}/../data/tx${index}.raw`, tx.toRaw());

if (!view)
return;

const undo = exports.makeTXUndo(tx, view);
const undoRaw = exports.serializeUndo(undo);

fs.writeFileSync(`${__dirname}/../data/utx${index}.raw`, undoRaw);
};

0 comments on commit 5a751d9

Please sign in to comment.