Skip to main content

Python TestRPC for ethereum

Project description

Join the chat at https://gitter.im/eth-tester-rpc/Lobby Build Status PyPI version Python versions

A rewrite of Piper Merriam’s eth-testrpc using eth-tester

The eth-teste-rpc is a tool for testing any code that needs to make calls to ethereums RPC API. It starts a server to which you can connect your application and run tests accordingly.It is built on top of py-evm.

Quickstart

pip install eth-tester-rpc

To check usage of the command:

$ py-testrpc --help

Options:
  -h, --host TEXT
  -p, --port INTEGER
  --help              Show this message and exit.

To start the server:

py-testrpc -p 8888

The above command will start a server at port 8888. The default port is 8545.

To make a connection using web3.py

from web3 import Web3

w3 = Web3(Web3.HTTPProvider("http://localhost:8888"))
print(w3.eth.blockNumber)

Developer Setup

If you would like to hack on eth-tester-rpc, please check out the Ethereum Development Tactical Manual for information on how we do:

  • Testing

  • Pull Requests

  • Code Style

  • Documentation

Development Environment Setup

You can set up your dev environment with:

git clone git@github.com:voith/eth-tester-rpc.git
cd eth-tester-rpc
virtualenv -p python3 venv
. venv/bin/activate
pip install -e .[dev]

Testing Setup

During development, you might like to have tests run on every file save.

Show flake8 errors on file change:

# Test flake8
when-changed -v -s -r -1 eth_tester_rpc/ tests/ -c "clear; flake8 eth_tester_rpc tests && echo 'flake8 success' || echo 'error'"

Run multi-process tests in one command, but without color:

# in the project root:
pytest --numprocesses=4 --looponfail --maxfail=1
# the same thing, succinctly:
pytest -n 4 -f --maxfail=1

Run in one thread, with color and desktop notifications:

cd venv
ptw --onfail "notify-send -t 5000 'Test failure ⚠⚠⚠⚠⚠' 'python 3 test on eth_tester_rpc failed'" ../tests ../eth_tester_rpc

Release setup

For Debian-like systems:

apt install pandoc

To release a new version:

make release bump=$$VERSION_PART_TO_BUMP$$

How to bumpversion

The version format for this repo is {major}.{minor}.{patch} for stable, and {major}.{minor}.{patch}-{stage}.{devnum} for unstable (stage can be alpha or beta).

To issue the next version in line, specify which part to bump, like make release bump=minor or make release bump=devnum.

If you are in a beta version, make release bump=stage will switch to a stable.

To issue an unstable version when the current version is stable, specify the new version explicitly, like make release bump="--new-version 4.0.0-alpha.1 devnum"

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

eth-tester-rpc-0.5.0b1.tar.gz (22.6 kB view details)

Uploaded Source

Built Distribution

eth_tester_rpc-0.5.0b1-py3-none-any.whl (26.5 kB view details)

Uploaded Python 3

File details

Details for the file eth-tester-rpc-0.5.0b1.tar.gz.

File metadata

  • Download URL: eth-tester-rpc-0.5.0b1.tar.gz
  • Upload date:
  • Size: 22.6 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.2.0 pkginfo/1.6.1 requests/2.25.0 setuptools/50.3.2 requests-toolbelt/0.9.1 tqdm/4.53.0 CPython/3.7.2

File hashes

Hashes for eth-tester-rpc-0.5.0b1.tar.gz
Algorithm Hash digest
SHA256 a2f96c0ede02b4797b94d61e26d852ea4623dac2889472bb23a30fde8088a588
MD5 f9534e5f5b2d5699e3247487b8c4817d
BLAKE2b-256 a47c46d1dda30a7f34fd9416d84dbcda1b7f939fa84acbaccda1067241333862

See more details on using hashes here.

File details

Details for the file eth_tester_rpc-0.5.0b1-py3-none-any.whl.

File metadata

  • Download URL: eth_tester_rpc-0.5.0b1-py3-none-any.whl
  • Upload date:
  • Size: 26.5 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.2.0 pkginfo/1.6.1 requests/2.25.0 setuptools/50.3.2 requests-toolbelt/0.9.1 tqdm/4.53.0 CPython/3.7.2

File hashes

Hashes for eth_tester_rpc-0.5.0b1-py3-none-any.whl
Algorithm Hash digest
SHA256 20d9e69a4ace50ec23bd93e3aab20d9defec8f175efae88eb519abd15fa6f5a0
MD5 43eba6996e29415bc8da1b9b04eb0dea
BLAKE2b-256 e08ad3515653e5fa14a24460162b46719f783bc91bafe8713fe5f841167f6cc2

See more details on using hashes here.

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page