|
|
|
/* global describe, it */
|
|
|
|
|
|
|
|
var assert = require('assert')
|
|
|
|
var bscript = require('../src/script')
|
|
|
|
var minimalData = require('minimaldata')
|
|
|
|
|
|
|
|
var fixtures = require('./fixtures/script.json')
|
|
|
|
|
|
|
|
describe('script', function () {
|
|
|
|
// TODO
|
|
|
|
describe('isCanonicalPubKey', function () {
|
|
|
|
it('rejects if not provided a Buffer', function () {
|
|
|
|
assert.strictEqual(false, bscript.isCanonicalPubKey(0))
|
|
|
|
})
|
|
|
|
it('rejects smaller than 33', function () {
|
|
|
|
for (var i = 0; i < 33; i++) {
|
|
|
|
assert.strictEqual(false, bscript.isCanonicalPubKey(new Buffer('', i)))
|
|
|
|
}
|
|
|
|
})
|
|
|
|
})
|
|
|
|
describe.skip('isCanonicalSignature', function () {})
|
|
|
|
|
|
|
|
describe('fromASM/toASM', function () {
|
|
|
|
fixtures.valid.forEach(function (f) {
|
|
|
|
if (f.scriptSig) {
|
|
|
|
it('encodes/decodes ' + f.scriptSig, function () {
|
|
|
|
var scriptSig = bscript.fromASM(f.scriptSig)
|
|
|
|
|
|
|
|
assert.strictEqual(bscript.toASM(scriptSig), f.scriptSig)
|
|
|
|
})
|
|
|
|
}
|
|
|
|
|
|
|
|
if (f.scriptPubKey) {
|
|
|
|
it('encodes/decodes ' + f.scriptPubKey, function () {
|
|
|
|
var scriptPubKey = bscript.fromASM(f.scriptPubKey)
|
|
|
|
|
|
|
|
assert.strictEqual(bscript.toASM(scriptPubKey), f.scriptPubKey)
|
|
|
|
})
|
|
|
|
}
|
|
|
|
})
|
|
|
|
})
|
|
|
|
|
|
|
|
describe('isPushOnly', function () {
|
|
|
|
fixtures.valid.forEach(function (f) {
|
|
|
|
if (f.scriptSig) {
|
|
|
|
it('returns ' + f.pushOnlySig + ' for ' + f.scriptSig, function () {
|
|
|
|
var script = bscript.fromASM(f.scriptSig)
|
|
|
|
var chunks = bscript.decompile(script)
|
|
|
|
|
|
|
|
assert.strictEqual(bscript.isPushOnly(chunks), f.pushOnlySig)
|
|
|
|
})
|
|
|
|
}
|
|
|
|
|
|
|
|
if (f.scriptPubKey) {
|
|
|
|
it('returns ' + f.pushOnly + ' for ' + f.scriptPubKey, function () {
|
|
|
|
var script = bscript.fromASM(f.scriptPubKey)
|
|
|
|
var chunks = bscript.decompile(script)
|
|
|
|
|
|
|
|
assert.strictEqual(bscript.isPushOnly(chunks), f.pushOnly)
|
|
|
|
})
|
|
|
|
}
|
|
|
|
})
|
|
|
|
})
|
|
|
|
|
|
|
|
describe('compile (via fromASM)', function () {
|
|
|
|
fixtures.valid.forEach(function (f) {
|
|
|
|
if (f.scriptSig) {
|
|
|
|
it('(' + f.type + ') compiles ' + f.scriptSig, function () {
|
|
|
|
var scriptSig = bscript.fromASM(f.scriptSig)
|
|
|
|
|
|
|
|
assert.strictEqual(scriptSig.toString('hex'), f.scriptSigHex)
|
|
|
|
|
|
|
|
if (f.nonstandard) {
|
|
|
|
var scriptSigNS = bscript.fromASM(f.nonstandard.scriptSig)
|
|
|
|
|
|
|
|
assert.strictEqual(scriptSigNS.toString('hex'), f.scriptSigHex)
|
|
|
|
}
|
|
|
|
})
|
|
|
|
}
|
|
|
|
|
|
|
|
if (f.scriptPubKey) {
|
|
|
|
it('(' + f.type + ') compiles ' + f.scriptPubKey, function () {
|
|
|
|
var scriptPubKey = bscript.fromASM(f.scriptPubKey)
|
|
|
|
|
|
|
|
assert.strictEqual(scriptPubKey.toString('hex'), f.scriptPubKeyHex)
|
|
|
|
})
|
|
|
|
}
|
|
|
|
})
|
|
|
|
})
|
|
|
|
|
|
|
|
describe('decompile', function () {
|
|
|
|
fixtures.valid.forEach(function (f) {
|
|
|
|
if (f.scriptSigHex) {
|
|
|
|
it('decompiles ' + f.scriptSig, function () {
|
|
|
|
var chunks = bscript.decompile(new Buffer(f.scriptSigHex, 'hex'))
|
|
|
|
|
|
|
|
assert.strictEqual(bscript.compile(chunks).toString('hex'), f.scriptSigHex)
|
|
|
|
assert.strictEqual(bscript.toASM(chunks), f.scriptSig)
|
|
|
|
|
|
|
|
if (f.nonstandard) {
|
|
|
|
var chunksNS = bscript.decompile(new Buffer(f.nonstandard.scriptSigHex, 'hex'))
|
|
|
|
|
|
|
|
assert.strictEqual(bscript.compile(chunksNS).toString('hex'), f.scriptSigHex)
|
|
|
|
|
|
|
|
// toASM converts verbatim, only `compile` transforms the script to a minimalpush compliant script
|
|
|
|
assert.strictEqual(bscript.toASM(chunksNS), f.nonstandard.scriptSig)
|
|
|
|
}
|
|
|
|
})
|
|
|
|
}
|
|
|
|
|
|
|
|
if (f.scriptPubKeyHex) {
|
|
|
|
it('decompiles ' + f.scriptPubKey, function () {
|
|
|
|
var chunks = bscript.decompile(new Buffer(f.scriptPubKeyHex, 'hex'))
|
|
|
|
|
|
|
|
assert.strictEqual(bscript.compile(chunks).toString('hex'), f.scriptPubKeyHex)
|
|
|
|
assert.strictEqual(bscript.toASM(chunks), f.scriptPubKey)
|
|
|
|
})
|
|
|
|
}
|
|
|
|
})
|
|
|
|
|
|
|
|
fixtures.invalid.decompile.forEach(function (f) {
|
|
|
|
it('decompiles ' + f.hex + ' to [] because of "' + f.description + '"', function () {
|
|
|
|
var chunks = bscript.decompile(new Buffer(f.hex, 'hex'))
|
|
|
|
|
|
|
|
assert.strictEqual(chunks.length, 0)
|
|
|
|
})
|
|
|
|
})
|
|
|
|
})
|
|
|
|
|
|
|
|
describe('SCRIPT_VERIFY_MINIMALDATA policy', function () {
|
|
|
|
fixtures.valid.forEach(function (f) {
|
|
|
|
if (f.scriptSigHex) {
|
|
|
|
it('compliant for ' + f.type + ' scriptSig ' + f.scriptSig, function () {
|
|
|
|
var script = new Buffer(f.scriptSigHex, 'hex')
|
|
|
|
|
|
|
|
assert(minimalData(script))
|
|
|
|
})
|
|
|
|
}
|
|
|
|
|
|
|
|
if (f.scriptPubKeyHex) {
|
|
|
|
it('compliant for ' + f.type + ' scriptPubKey ' + f.scriptPubKey, function () {
|
|
|
|
var script = new Buffer(f.scriptPubKeyHex, 'hex')
|
|
|
|
|
|
|
|
assert(minimalData(script))
|
|
|
|
})
|
|
|
|
}
|
|
|
|
})
|
|
|
|
|
|
|
|
function testEncodingForSize (i) {
|
|
|
|
it('compliant for data PUSH of length ' + i, function () {
|
|
|
|
var buffer = new Buffer(i)
|
|
|
|
var script = bscript.compile([buffer])
|
|
|
|
|
|
|
|
assert(minimalData(script), 'Failed for ' + i + ' length script: ' + script.toString('hex'))
|
|
|
|
})
|
|
|
|
}
|
|
|
|
|
|
|
|
for (var i = 0; i < 520; ++i) {
|
|
|
|
testEncodingForSize(i)
|
|
|
|
}
|
|
|
|
})
|
|
|
|
})
|