Skip to content

Latest commit

 

History

History
127 lines (84 loc) · 3.7 KB

README.md

File metadata and controls

127 lines (84 loc) · 3.7 KB

Local Testnet

The E2E tests run against local deployments of the parachain, relayer and ethereum (geth).

Requirements

Setup

Install NPM dependencies

yarn install

Polkadot

  • Clone the polkadot repository somewhere on your machine
  • Checkout commit release-v0.9.12.

Example:

git clone -n https://github.com/paritytech/polkadot.git
cd /path/to/polkadot
git checkout release-v0.9.12
cargo build --release

Configure testnet

Create an .envrc file in which to hold environment config, using .envrc-example as a template. make sure to override the POLKADOT_BIN variable to the location of the polkadot binary built in the previous step.

Example:

POLKADOT_BIN=/home/sally/code/polkadot/target/release/polkadot

Once the .envrc has been created, let direnv load it automatically:

direnv allow

Launch the testnet

Run the following script

scripts/start-services.sh

Wait until the "Testnet has been initialized" message

Go to polkadot-js and wait until the parachain has started producing blocks: https://polkadot.js.org/apps/?rpc=ws%3A%2F%2F127.0.0.1%3A11144#/explorer

You can see the relay chain by connecting to https://polkadot.js.org/apps/?rpc=ws%3A%2F%2F127.0.0.1%3A9944#/explorer

Confirm the block number is > 2

Troubleshooting

The start-services.sh script writes the following logs:

  • Parachain nodes: /tmp/snowbridge/{alice,bob,11144,11155}.log
  • Relay services: /tmp/snowbridge/{beefy,parachain,ethereum}-relay.log
  • Geth: /tmp/snowbridge/geth.log

E2E tests

Run the tests using the following command:

yarn test

These tests are meant to closely replicate real-world behaviour. This means that they also replicate real-world delays and confirmation times. This can take up to 4 minutes per test and ~20minutes for all tests.

Testing against a malicious contract

We also have a test environment that tests against a malicious contract that attempts to consume infinite gas. To setup this environment, run the start-services script with the malicious flag:

TEST_MALICIOUS_APP=1 scripts/start-services.sh

This will deploy and run everything as usual, but replace the dot app with a malicious one. Once everything is ready to go, run the tests for the malicious app:

yarn test ./test/malicious-dotapp.js

You should see the test pass, checking that message delivery works correctly and channel functionality is still secure without being affected by the malicious app.

Generating/Updating new test fixtures

Test fixtures are taken by running the service in full e2e test. The relayer should log the fixture data you need (code is in the relayer here, though may require a bit of manual copy/pasting to get perfectly it in the right format.