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.
		
		
		
		
		
			
		
			
				
	
	
		
			47 lines
		
	
	
		
			1.3 KiB
		
	
	
	
		
			Markdown
		
	
			
		
		
	
	
			47 lines
		
	
	
		
			1.3 KiB
		
	
	
	
		
			Markdown
		
	
| # Aya Integration Tests
 | |
| 
 | |
| The aya integration test suite is a set of tests to ensure that
 | |
| common usage behaviours work on real Linux distros
 | |
| 
 | |
| ## Prerequisites
 | |
| 
 | |
| You'll need:
 | |
| 
 | |
| 1. `rustup toolchain install nightly`
 | |
| 1. `rustup target add {aarch64,x86_64}-unknown-linux-musl`
 | |
| 1. `cargo install bpf-linker`
 | |
| 1. `libelf-dev` (`libelf-devel` on rpm-based distros)
 | |
| 1. `llvm` (for `llvm-objcopy`)
 | |
| 1. (virtualized only) `qemu`
 | |
| 
 | |
| ## Usage
 | |
| 
 | |
| From the root of this repository:
 | |
| 
 | |
| ### Native
 | |
| 
 | |
| ```bash
 | |
| cargo xtask integration-test local
 | |
| ```
 | |
| 
 | |
| ### Virtualized
 | |
| 
 | |
| ```bash
 | |
| cargo xtask integration-test vm --cache-dir <CACHE_DIR> <KERNEL_IMAGE>...
 | |
| ```
 | |
| 
 | |
| ### Writing an integration test
 | |
| 
 | |
| Tests should follow these guidelines:
 | |
| 
 | |
| - Rust eBPF code should live in `integration-ebpf/${NAME}.rs` and included in
 | |
|   `integration-ebpf/Cargo.toml` and `integration-test/src/lib.rs` using
 | |
|   `include_bytes_aligned!`.
 | |
| - C eBPF code should live in `integration-test/bpf/${NAME}.bpf.c`. It should be
 | |
|   added to the list of files in `integration-test/build.rs` and the list of
 | |
|   constants in `integration-test/src/lib.rs` using `include_bytes_aligned!`.
 | |
| - Tests should be added to `integration-test/tests`.
 | |
| - You may add a new module, or use an existing one.
 | |
| - Test functions should not return `anyhow::Result<()>` since this produces
 | |
|   errors without stack traces. Prefer to `panic!` instead.
 |