This folder defines the implementation for the interop tests.
You can run this test locally by having a local Redis instance and by having another peer that this test can dial or listen for. For example to test that we can dial/listen for ourselves we can do the following:
- Start redis (needed by the tests):
docker run --rm -it -p 6379:6379 redis/redis-stack
. - In one terminal run the dialer:
REDIS_ADDR=localhost:6379 ip="0.0.0.0" transport=quic-v1 security=quic muxer=quic is_dialer="true" cargo run --bin ping
- In another terminal, run the listener:
REDIS_ADDR=localhost:6379 ip="0.0.0.0" transport=quic-v1 security=quic muxer=quic is_dialer="false" cargo run --bin ping
To test the interop with other versions do something similar, except replace one of these nodes with the other version's interop test.
To run this test against all released libp2p versions you'll need to have the (libp2p/test-plans)[https://github.com/libp2p/test-plans] checked out. Then do the following:
- Build the image:
make
. - Build the images for all released versions in
libp2p/test-plans
:(cd <path to >/libp2p/test-plans/multidim-interop/ && make)
. - Make a folder for the specified extra versions:
mkdir extra-versions && mv ping-versions.json extra-versions
- Run the test:
RUST_LIBP2P_TEST_PLANS="$PWD"; (cd <path to >/libp2p/test-plans/multidim-interop/ && npm run test -- --extra-versions-dir=$RUST_LIBP2P_TEST_PLANS/extra-versions --name-filter="rust-libp2p-head")