mirror of https://github.com/aya-rs/aya
You cannot select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
f357be7db4
This commit uses the symbol table to discover all maps inside an ELF section. Instead of doing what libbpf does - divide the section data in to equal sized chunks - we read in to section data using the symbol address and offset, thus allowing us to support definitions of varying lengths. Signed-off-by: Dave Tucker <dave@dtucker.co.uk> |
3 years ago | |
---|---|---|
.. | ||
cases | 3 years ago | |
.gitignore | 3 years ago | |
README.md | 3 years ago |
README.md
Aya Regression Tests
The aya regression test suite is a set of tests to ensure that common usage behaviours work on real Linux distros
Prerequisites
This assumes you have a working Rust and Go toolchain on the host machine
rustup target add x86_64-unknown-linux-musl
- Install
rtf
:go install github.com/linuxkit/rtf@latest
- Install rust-script:
cargo install rust-script
- Install
qemu
andcloud-init-utils
package - or any package that providescloud-localds
It is not required, but the tests run significantly faster if you use sccache
You may also use the docker image to run the tests:
docker run -it --rm --device /dev/kvm -v/home/dave/dev/aya-rs/aya:/src -w /src/test ghcr.io/aya-rs/aya-test-rtf:main
Usage
To read more about how to use rtf
, see the documentation
Run the tests with verbose output
rtf -vvv run
Run the tests using an older kernel
AYA_TEST_IMAGE=centos8 rtf -vvv run
Writing a test
Tests should follow this pattern:
- The eBPF code should be in a file named
${NAME}.ebpf.rs
- The userspace code should be in a file named
${NAME}.rs
- The userspace program should make assertions and exit with a non-zero return code to signal failure
- VM start and stop is handled by the framework
- Any files copied to the VM should be cleaned up afterwards
See ./cases
for examples