asterinas/test/initramfs
Qingsong Chen f6f896ef64 Refactor regression test to support fine-grained build 2026-02-11 07:43:58 +00:00
..
nix Refactor regression test to support fine-grained build 2026-02-11 07:43:58 +00:00
src Refactor regression test to support fine-grained build 2026-02-11 07:43:58 +00:00
.gitignore Move test/* to test/initramfs/* 2026-01-13 11:53:34 -08:00
Makefile Refactor regression test to support fine-grained build 2026-02-11 07:43:58 +00:00
README.md Refactor regression test to support fine-grained build 2026-02-11 07:43:58 +00:00

README.md

Initramfs-Based Test Suites

This directory contains the test suites of Asterinas running in initramfs, including various test programs, benchmarks, syscall test suites, and necessary configuration files. The structure of the test directory is designed to be modular and flexible, supporting multiple CPU architectures and a streamlined workflow for building and running tests.

Directory Structure

initramfs/
├── src/
│   ├── benchmark/     # Supported benchmark test suites
│   ├── regression/    # Regression tests
│   ├── etc/           # Configuration files
│   └── syscall/       # Syscall test suites
│       ├── ltp/       # LTP syscall test suite
│       └── gvisor/    # Gvisor syscall test suite
├── nix/
│   ├── benchmark/     # Nix expressions for `benchmark`
│   ├── regression/    # Nix expressions for `regression`
│   ├── syscall/       # Nix expressions for `syscall`
│   └── initramfs.nix  # Nix expression for packaging initramfs
├── Makefile
└── README.md

Building and Packaging Tests

Most tests in this directory are compiled and packaged using Nix, a powerful package manager. This ensures consistency and reproducibility across environments.

Note: If you are adding a new test to the regression directory, ensure that it supports multiple architectures. Some of the existing tests lack proper architecture-specific handling.

Syscall Test Suite - Gvisor Exception

While most tests rely on Nix for compilation, the gvisor syscall test suite currently cannot be built with Nix. Instead, the gvisor tests are compiled in the Docker image. For details, refer to tools/docker/Dockerfile.

Multi-Architecture Support

The test suite supports building for multiple architectures, including x86_64 and riscv64. You can specify the desired architecture by running:

make kernel OSDK_TARGET_ARCH=x86_64
# or
make kernel OSDK_TARGET_ARCH=riscv64

The build artifacts (initramfs) can be found in the test/initramfs/build directory after the compilation.

Supported Benchmarks

The following benchmarks are currently supported:

  • fio
  • hackbench
  • iperf3
  • lmbench
  • memcached
  • nginx
  • redis
  • schbench
  • sqlite
  • sysbench

Architecture Compatibility

All benchmarks except sysbench support both x86_64 and riscv64 architectures.

These benchmarks are precompiled and packaged into the Docker image for convenience. Refer to tools/docker/nix/Dockerfile for details.

Adding New Benchmarks

We recommend utilizing Nix when adding new benchmarks. To check if a benchmark is already available, use the Nix Package Search. If a package exists in the Nix channel, you can directly use it or modify it if necessary.

If the desired benchmark is not available or cannot be easily adapted, you can add a custom .nix file to package it manually. Place the .nix files under the test/initramfs/nix/benchmark directory.

Configuration Files

Configuration files required by benchmarks or regression tests should be placed in the test/initramfs/src/etc directory.

If additional configuration files or directories are needed, ensure they are appropriately packaged by updating the initramfs.nix file.

Notes for Developers

  • Nix Usage: Use Nix whenever possible to manage dependencies and builds for ease of maintenance and consistency.
  • Multi-Architecture Support: Ensure new regression tests or benchmarks properly support multiple CPU architectures.