mirror of
https://github.com/cloud-hypervisor/cloud-hypervisor.git
synced 2025-01-03 11:25:20 +00:00
ci: Separate parallel vs sequential tests
In order to differentiate tests that can be run in parallel versus tests that must be run on their own, we move all tests into dedicated modules. The point is to avoid glitches in results that can be caused by the fact that other tests (hence VMs) are running at the same time. Signed-off-by: Sebastien Boeuf <sebastien.boeuf@intel.com>
This commit is contained in:
parent
2a6eb31d5b
commit
bb9174601a
@ -222,21 +222,31 @@ sudo bash -c "echo 1000000 > /sys/kernel/mm/ksm/pages_to_scan"
|
|||||||
sudo bash -c "echo 10 > /sys/kernel/mm/ksm/sleep_millisecs"
|
sudo bash -c "echo 10 > /sys/kernel/mm/ksm/sleep_millisecs"
|
||||||
sudo bash -c "echo 1 > /sys/kernel/mm/ksm/run"
|
sudo bash -c "echo 1 > /sys/kernel/mm/ksm/run"
|
||||||
|
|
||||||
# Ensure test binary has the same caps as the cloud-hypervisor one
|
|
||||||
time cargo test --no-run --features "integration_tests" -- --nocapture || exit 1
|
|
||||||
ls target/debug/deps/cloud_hypervisor-* | xargs -n 1 sudo setcap cap_net_admin+ep
|
|
||||||
|
|
||||||
# test_vfio relies on hugepages
|
# test_vfio relies on hugepages
|
||||||
echo 4096 | sudo tee /proc/sys/vm/nr_hugepages
|
echo 4096 | sudo tee /proc/sys/vm/nr_hugepages
|
||||||
sudo chmod a+rwX /dev/hugepages
|
sudo chmod a+rwX /dev/hugepages
|
||||||
|
|
||||||
|
# Ensure test binary has the same caps as the cloud-hypervisor one
|
||||||
|
time cargo test --no-run --features "integration_tests" -- --nocapture || exit 1
|
||||||
|
ls target/debug/deps/cloud_hypervisor-* | xargs -n 1 sudo setcap cap_net_admin+ep
|
||||||
|
|
||||||
sudo adduser $USER kvm
|
sudo adduser $USER kvm
|
||||||
newgrp kvm << EOF
|
newgrp kvm << EOF
|
||||||
export RUST_BACKTRACE=1
|
export RUST_BACKTRACE=1
|
||||||
time cargo test --features "integration_tests" "$@" -- --nocapture
|
time cargo test --features "integration_tests" "tests::parallel::$@" -- --nocapture
|
||||||
EOF
|
EOF
|
||||||
RES=$?
|
RES=$?
|
||||||
|
|
||||||
|
# Run some tests in sequence since the result could be affected by other tests
|
||||||
|
# running in parallel.
|
||||||
|
if [ $RES -eq 0 ]; then
|
||||||
|
newgrp kvm << EOF
|
||||||
|
export RUST_BACKTRACE=1
|
||||||
|
time cargo test --features "integration_tests" "tests::sequential::$@" -- --nocapture --test-threads=1
|
||||||
|
EOF
|
||||||
|
RES=$?
|
||||||
|
fi
|
||||||
|
|
||||||
if [ $RES -eq 0 ]; then
|
if [ $RES -eq 0 ]; then
|
||||||
# virtio-mmio based testing
|
# virtio-mmio based testing
|
||||||
cargo build --release --target $BUILD_TARGET --no-default-features --features "mmio"
|
cargo build --release --target $BUILD_TARGET --no-default-features --features "mmio"
|
||||||
@ -252,10 +262,20 @@ if [ $RES -eq 0 ]; then
|
|||||||
|
|
||||||
newgrp kvm << EOF
|
newgrp kvm << EOF
|
||||||
export RUST_BACKTRACE=1
|
export RUST_BACKTRACE=1
|
||||||
time cargo test --features "integration_tests,mmio" "$@" -- --nocapture
|
time cargo test --features "integration_tests,mmio" "tests::parallel::$@" -- --nocapture
|
||||||
EOF
|
EOF
|
||||||
|
|
||||||
RES=$?
|
RES=$?
|
||||||
|
|
||||||
|
# Run some tests in sequence since the result could be affected by other tests
|
||||||
|
# running in parallel.
|
||||||
|
if [ $RES -eq 0 ]; then
|
||||||
|
newgrp kvm << EOF
|
||||||
|
export RUST_BACKTRACE=1
|
||||||
|
time cargo test --features "integration_tests,mmio" "tests::sequential::$@" -- --nocapture --test-threads=1
|
||||||
|
EOF
|
||||||
|
RES=$?
|
||||||
|
fi
|
||||||
fi
|
fi
|
||||||
|
|
||||||
# Tear VFIO test network down
|
# Tear VFIO test network down
|
||||||
|
2345
tests/integration.rs
2345
tests/integration.rs
File diff suppressed because it is too large
Load Diff
Loading…
Reference in New Issue
Block a user