From 6f9e69b3eac4fdc030c05a043947de8a6b1f156d Mon Sep 17 00:00:00 2001 From: Huijing Hei Date: Tue, 16 May 2023 15:47:13 +0800 Subject: [PATCH] tests: add test `nvme-symlink` to verify GCP udev rules Force this test to not run by default unless named specifically or `--tag confidential` is passed to `kola run`, also requires `--gcp-machinetype n2d-standard-2 --gcp-confidential-vm` It will create confidential instance on GCP with 1 nvme persistent disk and 1 local ssd disk, then check the new udev rules make effect. Based on https://github.com/coreos/coreos-assembler/pull/3474 and https://github.com/coreos/coreos-assembler/pull/3477. Fix https://github.com/coreos/fedora-coreos-tracker/issues/1457 --- tests/kola/platforms/gcp/data/commonlib.sh | 1 + tests/kola/platforms/gcp/nvme-symlink | 60 ++++++++++++++++++++++ 2 files changed, 61 insertions(+) create mode 120000 tests/kola/platforms/gcp/data/commonlib.sh create mode 100755 tests/kola/platforms/gcp/nvme-symlink diff --git a/tests/kola/platforms/gcp/data/commonlib.sh b/tests/kola/platforms/gcp/data/commonlib.sh new file mode 120000 index 0000000000..b8dcbdca1a --- /dev/null +++ b/tests/kola/platforms/gcp/data/commonlib.sh @@ -0,0 +1 @@ +../../../data/commonlib.sh \ No newline at end of file diff --git a/tests/kola/platforms/gcp/nvme-symlink b/tests/kola/platforms/gcp/nvme-symlink new file mode 100755 index 0000000000..dabe833f32 --- /dev/null +++ b/tests/kola/platforms/gcp/nvme-symlink @@ -0,0 +1,60 @@ +#!/bin/bash +## kola: +## description: Verify new GCP udev rules work well on confidential instance. +## additionalDisks: ["375G:interface=NVME"] +## platforms: gcp +## requiredTag: confidential + +# See https://issues.redhat.com/browse/OCPBUGS-7582 +# https://github.com/coreos/fedora-coreos-tracker/issues/1457 +# +# Force this test to not run by default unless named specifically +# or `--tag confidential` is passed to `kola run`, also requires +# `--gcp-machinetype n2d-standard-2 --gcp-confidential-vm` +# +# It will create confidential instance on GCP with 1 nvme persistent disk +# and 1 local ssd disk, then check the new udev rules make effect. +# Note: each local SSD is 375 GB in size, refer to https://cloud.google.com/compute/docs/disks/local-ssd + +set -xeuo pipefail + +. $KOLA_EXT_DATA/commonlib.sh + +# check instance has 2 disks +nvme_info=$(nvme list-subsys -o json) +nvme_count=$(jq -r ".[].Subsystems | length" <<< "$nvme_info") +if [ $nvme_count -ne 2 ]; then + fatal "instance does not have 2 disks" +fi + +# check nvme device +has_nvme() { + local nvme_disk=$(jq -r ".[].Subsystems[].Paths[] | select(.Name == \"${disk}\").Name" <<< "$nvme_info") + if [ -n "${nvme_disk}" ]; then + if [ ! -e "${device}" ]; then + fatal "instance has nvme device but no ${disk} accessible" + fi + fi +} + +# check symlink +check_symlink() { + local tmpfile=$(mktemp) + /usr/lib/udev/google_nvme_id -d "${device}" > ${tmpfile} + source ${tmpfile} + if [ ! -n "${ID_SERIAL_SHORT:-}" ]; then + fatal "can not get nvme ${device} ID_SERIAL_SHORT" + fi + + local link="/dev/disk/by-id/google-${ID_SERIAL_SHORT}" + if ! ls -l "${link}"; then + fatal "can not find ${device} symlink ${link}" + fi +} + +for disk in nvme0 nvme1; do + device="/dev/${disk}n1" + has_nvme + check_symlink + ok "Find ${device} symlink" +done