An alternative full node implementation of LBRY's blockchain written in Go (golang)
Find a file
Dave Collins e30ceb5947 Cleanup and fix operational tests.
This commit makes several changes to the operation tests as follows:

- Ensure the database is closed between each operational mode test as
  otherwise  the database is locked when trying to reopening it which
  makes it unusable
- Make the insert tests error after a single failure since every test
  afterwards is guaranteed to fail as well
- Remove some of the logging statements which cluttered up the failed test
  prints making it harder to see why a given test failed
- Make a couple of the log messages more descriptive
2013-05-29 16:11:13 -05:00
sqlite3 Cleanup and fix operational tests. 2013-05-29 16:11:13 -05:00
.gitignore Initial commit. 2013-05-28 19:03:53 -05:00
db.go Add InsertBlockData needed by tests to interface. 2013-05-29 15:30:26 -05:00
doc.go Initial implementation. 2013-05-29 10:09:26 -05:00
LICENSE Initial implementation. 2013-05-29 10:09:26 -05:00
log.go Initial implementation. 2013-05-29 10:09:26 -05:00
README.md Initial implementation. 2013-05-29 10:09:26 -05:00

btcdb

Package btcdb provides a database interface for the bitcoin block chain and transactions. There is a test suite which is aiming to reach 100% code coverage coverage. See test_coverage.txt for the current coverage (using gocov). On a UNIX-like OS, the script cov_report.sh can be used to generate the report. Package btcjson is licensed under the liberal ISC license.

Sample Use

	db, err := btcdb.CreateDB("sqlite", "dbexample")
	newHeight, err := db.InsertBlock(block)
	db.Sync()

Documentation

Full go doc style documentation for the project can be viewed online without installing this package by using the GoDoc site here.

You can also view the documentation locally once the package is installed with the godoc tool by running godoc -http=":6060" and pointing your browser to http://localhost:6060/pkg/github.com/conformal/btcdb

Installation

$ go get github.com/conformal/btcdb

TODO

  • Increase test coverage to 100%
  • Allow other database backends

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 Conformal. 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 btcdb is licensed under the liberal ISC License.