lbcd/txscript
Dave Collins 153dca5c1e
txscript: Convert reference tests to new format.
This updates the data driven transaction script tests to use the most
recent format and test data as implemented by Core so the test data can
more easily be updated and help prove cross-compatibility correctness.

In particular, the new format combines the previously separate valid and
invalid test data files into a single file and adds a field for the
expected result.  This is a nice improvement since it means tests can
now ensure script failures are due to a specific expected reason as
opposed to only generically detecting failure as the previous format
required.

The btcd script engine typically returns more fine grained errors than
the test data expects, so the test adapter handles this by allowing
expected errors in the test data to be mapped to multiple txscript
errors.

It should also be noted that the tests related to segwit have been
stripped from the data since the segwit PR has not landed in master yet,
however the test adapter does recognize the new ability for optional
segwit data to be supplied, though it will need to properly construct
the transaction using that data when the time comes.
2017-01-12 13:13:21 -06:00
..
data txscript: Convert reference tests to new format. 2017-01-12 13:13:21 -06:00
consensus.go txscript: Implement CheckSequenceVerify (BIP0112) 2016-10-19 12:06:44 -04:00
doc.go txscript: Significantly improve errors. 2017-01-12 13:12:39 -06:00
engine.go txscript: Significantly improve errors. 2017-01-12 13:12:39 -06:00
engine_test.go txscript: Significantly improve errors. 2017-01-12 13:12:39 -06:00
error.go txscript: Significantly improve errors. 2017-01-12 13:12:39 -06:00
error_test.go txscript: Significantly improve errors. 2017-01-12 13:12:39 -06:00
example_test.go wire: Make NewMsgTx accept the tx version. 2016-10-27 14:09:29 -05:00
log.go Relicense to the btcsuite developers. 2015-05-01 12:00:56 -05:00
log_test.go txscript: Consolidate tests into txscript package. 2016-10-20 09:28:33 -05:00
opcode.go txscript: Significantly improve errors. 2017-01-12 13:12:39 -06:00
opcode_test.go txscript: Significantly improve errors. 2017-01-12 13:12:39 -06:00
README.md txscript: Fix typo in README 2016-01-29 12:39:11 -08:00
reference_test.go txscript: Convert reference tests to new format. 2017-01-12 13:13:21 -06:00
script.go txscript: Significantly improve errors. 2017-01-12 13:12:39 -06:00
script_test.go txscript: Significantly improve errors. 2017-01-12 13:12:39 -06:00
scriptbuilder.go txscript: Significantly improve errors. 2017-01-12 13:12:39 -06:00
scriptbuilder_test.go txscript: Significantly improve errors. 2017-01-12 13:12:39 -06:00
scriptnum.go txscript: Significantly improve errors. 2017-01-12 13:12:39 -06:00
scriptnum_test.go txscript: Significantly improve errors. 2017-01-12 13:12:39 -06:00
sigcache.go chainhash: Abstract hash logic to new package. (#729) 2016-08-08 14:04:33 -05:00
sigcache_test.go chainhash: Abstract hash logic to new package. (#729) 2016-08-08 14:04:33 -05:00
sign.go Unassign some TODO's 2016-11-15 17:47:33 -06:00
sign_test.go wire: Make NewMsgTx accept the tx version. 2016-10-27 14:09:29 -05:00
stack.go txscript: Significantly improve errors. 2017-01-12 13:12:39 -06:00
stack_test.go txscript: Significantly improve errors. 2017-01-12 13:12:39 -06:00
standard.go txscript: Significantly improve errors. 2017-01-12 13:12:39 -06:00
standard_test.go txscript: Significantly improve errors. 2017-01-12 13:12:39 -06:00

txscript

[Build Status] (https://travis-ci.org/btcsuite/btcd) ![ISC License] (http://img.shields.io/badge/license-ISC-blue.svg) [GoDoc] (http://godoc.org/github.com/btcsuite/btcd/txscript)

Package txscript implements the bitcoin transaction script language. There is a comprehensive test suite.

This package has intentionally been designed so it can be used as a standalone package for any projects needing to use or validate bitcoin transaction scripts.

Bitcoin Scripts

Bitcoin provides a stack-based, FORTH-like language for the scripts in the bitcoin transactions. This language is not turing complete although it is still fairly powerful. A description of the language can be found at https://en.bitcoin.it/wiki/Script

Installation and Updating

$ go get -u github.com/btcsuite/btcd/txscript

Examples

GPG Verification Key

All official release tags are signed by Conformal so users can ensure the code has not been tampered with and is coming from the btcsuite developers. To verify the signature perform the following:

  • Download the public key from the Conformal website at https://opensource.conformal.com/GIT-GPG-KEY-conformal.txt

  • Import the public key into your GPG keyring:

    gpg --import GIT-GPG-KEY-conformal.txt
    
  • Verify the release tag with the following command where TAG_NAME is a placeholder for the specific tag:

    git tag -v TAG_NAME
    

License

Package txscript is licensed under the copyfree ISC License.