|
| 1 | +#!/bin/bash |
| 2 | +set -x |
| 3 | + |
| 4 | +source $HOME/.cargo/env |
| 5 | + |
| 6 | +CH_VERSION="v0.8.0" |
| 7 | +rm cloud-hypervisor |
| 8 | +wget --quiet "https://github.com/cloud-hypervisor/cloud-hypervisor/releases/download/$CH_VERSION/cloud-hypervisor" || exit 1 |
| 9 | +chmod +x cloud-hypervisor |
| 10 | + |
| 11 | +WORKLOADS_DIR="$HOME/workloads" |
| 12 | +mkdir -p "$WORKLOADS_DIR" |
| 13 | + |
| 14 | + |
| 15 | +CLEAR_OS_IMAGE_NAME="clear-31311-cloudguest.img" |
| 16 | +CLEAR_OS_IMAGE_URL="https://cloudhypervisorstorage.blob.core.windows.net/images/$CLEAR_OS_IMAGE_NAME" |
| 17 | +CLEAR_OS_IMAGE="$WORKLOADS_DIR/$CLEAR_OS_IMAGE_NAME" |
| 18 | +if [ ! -f "$CLEAR_OS_IMAGE" ]; then |
| 19 | + pushd $WORKLOADS_DIR |
| 20 | + wget --quiet $CLEAR_OS_IMAGE_URL || exit 1 |
| 21 | + popd |
| 22 | +fi |
| 23 | + |
| 24 | +BIONIC_OS_IMAGE_NAME="bionic-server-cloudimg-amd64.img" |
| 25 | +BIONIC_OS_IMAGE_URL="https://cloudhypervisorstorage.blob.core.windows.net/images/$BIONIC_OS_IMAGE_NAME" |
| 26 | +BIONIC_OS_IMAGE="$WORKLOADS_DIR/$BIONIC_OS_IMAGE_NAME" |
| 27 | +if [ ! -f "$BIONIC_OS_IMAGE" ]; then |
| 28 | + pushd $WORKLOADS_DIR |
| 29 | + wget --quiet $BIONIC_OS_IMAGE_URL || exit 1 |
| 30 | + popd |
| 31 | +fi |
| 32 | + |
| 33 | +BIONIC_OS_RAW_IMAGE_NAME="bionic-server-cloudimg-amd64-raw.img" |
| 34 | +BIONIC_OS_RAW_IMAGE="$WORKLOADS_DIR/$BIONIC_OS_RAW_IMAGE_NAME" |
| 35 | +if [ ! -f "$BIONIC_OS_RAW_IMAGE" ]; then |
| 36 | + pushd $WORKLOADS_DIR |
| 37 | + qemu-img convert -p -f qcow2 -O raw $BIONIC_OS_IMAGE_NAME $BIONIC_OS_RAW_IMAGE_NAME || exit 1 |
| 38 | + popd |
| 39 | +fi |
| 40 | + |
| 41 | + |
| 42 | +FOCAL_OS_IMAGE_NAME="focal-server-cloudimg-amd64.img" |
| 43 | +FOCAL_OS_IMAGE_URL="https://cloudhypervisorstorage.blob.core.windows.net/images/$FOCAL_OS_IMAGE_NAME" |
| 44 | +FOCAL_OS_IMAGE="$WORKLOADS_DIR/$FOCAL_OS_IMAGE_NAME" |
| 45 | +if [ ! -f "$FOCAL_OS_IMAGE" ]; then |
| 46 | + pushd $WORKLOADS_DIR |
| 47 | + wget --quiet $FOCAL_OS_IMAGE_URL || exit 1 |
| 48 | + popd |
| 49 | +fi |
| 50 | + |
| 51 | +FOCAL_OS_RAW_IMAGE_NAME="focal-server-cloudimg-amd64-raw.img" |
| 52 | +FOCAL_OS_RAW_IMAGE="$WORKLOADS_DIR/$FOCAL_OS_RAW_IMAGE_NAME" |
| 53 | +if [ ! -f "$FOCAL_OS_RAW_IMAGE" ]; then |
| 54 | + pushd $WORKLOADS_DIR |
| 55 | + qemu-img convert -p -f qcow2 -O raw $FOCAL_OS_IMAGE_NAME $FOCAL_OS_RAW_IMAGE_NAME || exit 1 |
| 56 | + popd |
| 57 | +fi |
| 58 | + |
| 59 | +cargo install cargo-xbuild |
| 60 | +rustup component add rust-src |
| 61 | +cargo xbuild --release --target target.json |
| 62 | + |
| 63 | +sudo adduser $USER kvm |
| 64 | +newgrp kvm << EOF |
| 65 | +export RUST_BACKTRACE=1 |
| 66 | +cargo test --features "integration_tests" -- --test-threads=1 test_boot |
| 67 | +EOF |
0 commit comments