bitcoinjs-lib/test/script.js

158 lines
4.8 KiB
JavaScript
Raw Normal View History

2015-02-23 10:36:57 +11:00
/* global describe, it */
var assert = require('assert')
var bscript = require('../src/script')
2016-08-31 15:21:36 +10:00
var minimalData = require('minimaldata')
2015-08-20 13:31:29 +10:00
var fixtures = require('./fixtures/script.json')
var fixtures2 = require('./fixtures/templates.json')
2015-08-20 13:31:29 +10:00
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++) {
2017-04-19 17:39:16 +10:00
assert.strictEqual(false, bscript.isCanonicalPubKey(Buffer.from('', i)))
}
})
})
2015-02-23 10:36:57 +11:00
describe.skip('isCanonicalSignature', function () {})
2015-08-14 11:16:17 +10:00
describe('fromASM/toASM', function () {
fixtures.valid.forEach(function (f) {
it('encodes/decodes ' + f.asm, function () {
var script = bscript.fromASM(f.asm)
assert.strictEqual(bscript.toASM(script), f.asm)
})
2015-08-14 11:16:17 +10:00
})
fixtures.invalid.fromASM.forEach(function (f) {
it('throws ' + f.description, function () {
assert.throws(function () {
bscript.fromASM(f.script)
}, new RegExp(f.description))
})
})
2015-08-14 11:16:17 +10:00
})
describe('fromASM/toASM (templates)', function () {
fixtures2.valid.forEach(function (f) {
if (f.inputHex) {
var ih = bscript.toASM(Buffer.from(f.inputHex, 'hex'))
it('encodes/decodes ' + ih, function () {
var script = bscript.fromASM(f.input)
assert.strictEqual(script.toString('hex'), f.inputHex)
assert.strictEqual(bscript.toASM(script), f.input)
})
}
if (f.outputHex) {
it('encodes/decodes ' + f.output, function () {
var script = bscript.fromASM(f.output)
assert.strictEqual(script.toString('hex'), f.outputHex)
assert.strictEqual(bscript.toASM(script), f.output)
})
}
})
})
describe('isPushOnly', function () {
fixtures.valid.forEach(function (f) {
it('returns ' + !!f.stack + ' for ' + f.asm, function () {
var script = bscript.fromASM(f.asm)
var chunks = bscript.decompile(script)
assert.strictEqual(bscript.isPushOnly(chunks), !!f.stack)
})
})
})
2016-12-15 10:57:53 +11:00
describe('toStack', function () {
fixtures.valid.forEach(function (f) {
it('returns ' + !!f.stack + ' for ' + f.asm, function () {
if (!f.stack || !f.asm) return
var script = bscript.fromASM(f.asm)
2016-12-15 10:57:53 +11:00
var stack = bscript.toStack(script)
assert.deepEqual(stack.map(function (x) {
return x.toString('hex')
}), f.stack)
assert.equal(bscript.toASM(bscript.compile(stack)), f.asm, 'should rebuild same script from stack')
2016-12-15 10:57:53 +11:00
})
})
})
describe('compile (via fromASM)', function () {
2015-08-14 11:16:17 +10:00
fixtures.valid.forEach(function (f) {
it('(' + f.type + ') compiles ' + f.asm, function () {
var scriptSig = bscript.fromASM(f.asm)
assert.strictEqual(scriptSig.toString('hex'), f.script)
if (f.nonstandard) {
var scriptSigNS = bscript.fromASM(f.nonstandard.scriptSig)
2015-08-14 11:16:17 +10:00
assert.strictEqual(scriptSigNS.toString('hex'), f.script)
}
})
2015-08-14 11:16:17 +10:00
})
})
describe('decompile', function () {
fixtures.valid.forEach(function (f) {
it('decompiles ' + f.asm, function () {
2017-04-19 17:39:16 +10:00
var chunks = bscript.decompile(Buffer.from(f.script, 'hex'))
2015-08-14 11:16:17 +10:00
assert.strictEqual(bscript.compile(chunks).toString('hex'), f.script)
assert.strictEqual(bscript.toASM(chunks), f.asm)
if (f.nonstandard) {
2017-04-19 17:39:16 +10:00
var chunksNS = bscript.decompile(Buffer.from(f.nonstandard.scriptSigHex, 'hex'))
assert.strictEqual(bscript.compile(chunksNS).toString('hex'), f.script)
// toASM converts verbatim, only `compile` transforms the script to a minimalpush compliant script
assert.strictEqual(bscript.toASM(chunksNS), f.nonstandard.scriptSig)
}
})
2015-08-14 11:16:17 +10:00
})
fixtures.invalid.decompile.forEach(function (f) {
it('decompiles ' + f.script + ' to [] because of "' + f.description + '"', function () {
2017-04-19 17:39:16 +10:00
var chunks = bscript.decompile(Buffer.from(f.script, 'hex'))
2015-08-14 11:16:17 +10:00
assert.strictEqual(chunks.length, 0)
})
})
})
2016-08-31 15:21:36 +10:00
describe('SCRIPT_VERIFY_MINIMALDATA policy', function () {
fixtures.valid.forEach(function (f) {
it('compliant for ' + f.type + ' scriptSig ' + f.asm, function () {
2017-04-19 17:39:16 +10:00
var script = Buffer.from(f.script, 'hex')
2016-08-31 15:21:36 +10:00
assert(minimalData(script))
})
2016-08-31 15:21:36 +10:00
})
function testEncodingForSize (i) {
it('compliant for data PUSH of length ' + i, function () {
2017-04-19 17:39:16 +10:00
var buffer = Buffer.alloc(i)
2016-08-31 15:21:36 +10:00
var script = bscript.compile([buffer])
assert(minimalData(script), 'Failed for ' + i + ' length script: ' + script.toString('hex'))
2016-08-31 15:21:36 +10:00
})
}
for (var i = 0; i < 520; ++i) {
testEncodingForSize(i)
}
})
})