Common utilities for Ethereum https://nimbus.status.im
Go to file
kdeme 44b30ef0cb Add all message types and a basic implementation of talkreq/talkresp 2020-10-16 21:20:47 +03:00
doc Update discv5.md 2020-10-05 15:47:40 +02:00
eth Add all message types and a basic implementation of talkreq/talkresp 2020-10-16 21:20:47 +03:00
tests Support findnode with multiple distances in discv5.1 2020-10-16 21:20:47 +03:00
.appveyor.yml Fix enr deserialization crash + more tests + fuzz test (#274) 2020-07-11 01:28:53 +02:00
.gitignore use bearssl rng throughout (#265) 2020-07-07 10:56:26 +02:00
.travis.yml Fix enr deserialization crash + more tests + fuzz test (#274) 2020-07-11 01:28:53 +02:00
LICENSE-APACHEv2 Moved eth-common to eth 2019-02-05 12:10:36 +02:00
LICENSE-MIT Moved eth-common to eth 2019-02-05 12:10:36 +02:00
README.md Update readme.md with link to fuzzing readme.md [skip ci] 2020-07-21 11:01:58 +02:00
eth.nimble Add discovery v5.1 implementation 2020-10-16 21:20:47 +03:00

README.md

eth - Eth Common Library

License: Apache License: MIT Stability: experimental

Introduction

Ethereum-related utilities written in Nim. Includes things like Bloom filters, private/public key utilities, RLP, devp2p, and more.

Docs

Prerequisites

  • Nim & Nimble
  • RocksDB, SQLite, LMDB (required for the trie backend tests)

E.g. on Ubuntu one can run:

apt install -y librocksdb-dev liblmdb-dev sqlite3

Building & Testing

# Install required modules
nimble install
# Run full test suite
nimble test

You can also run specific parts of the test suite, e.g.:

# Test p2p functionality
nimble test_p2p
# Test rlp functionality
nimble test_rlp

Fuzzing

Next to the test suite, there are also several fuzzing test cases available. How these can be run is explained in the fuzzing readme.

License

Licensed and distributed under either of

or

at your option. This file may not be copied, modified, or distributed except according to those terms.