Merge pull request #7165 from sprt/k8s-block-volume-test

tests: Add `k8s-block-volume` test to GHA CI
This commit is contained in:
Aurélien Bombo 2024-09-30 13:26:18 -07:00 committed by GitHub
commit b49800633d
No known key found for this signature in database
GPG Key ID: B5690EEEBB952194
6 changed files with 148 additions and 0 deletions

View File

@ -0,0 +1,85 @@
#!/usr/bin/env bats
#
# Copyright (c) 2019 Intel Corporation
#
# SPDX-License-Identifier: Apache-2.0
#
load "${BATS_TEST_DIRNAME}/lib.sh"
load "${BATS_TEST_DIRNAME}/../../common.bash"
load "${BATS_TEST_DIRNAME}/tests_common.sh"
setup() {
get_pod_config_dir
node="$(get_one_kata_node)"
pod_name="pod-block-pv"
volume_name="block-loop-pv"
volume_claim="block-loop-pvc"
ctr_dev_path="/dev/xda"
vol_capacity="500M"
# Create Loop Device
tmp_disk_image=$(exec_host "$node" mktemp --tmpdir disk.XXXXXX.img)
exec_host "$node" truncate "$tmp_disk_image" --size "$vol_capacity"
loop_dev=$(exec_host "$node" sudo losetup -f)
exec_host "$node" sudo losetup "$loop_dev" "$tmp_disk_image"
}
@test "Block Storage Support" {
# Create Storage Class
kubectl create -f volume/local-storage.yaml
# Create Persistent Volume
tmp_pv_yaml=$(mktemp --tmpdir block_persistent_vol.XXXXX.yaml)
sed -e "s|LOOP_DEVICE|${loop_dev}|" volume/block-loop-pv.yaml > "$tmp_pv_yaml"
node_name="$(kubectl get node -o name)"
sed -i "s|HOSTNAME|${node_name##node/}|" "$tmp_pv_yaml"
sed -i "s|CAPACITY|${vol_capacity}|" "$tmp_pv_yaml"
kubectl create -f "$tmp_pv_yaml"
cmd="kubectl get pv/${volume_name} | grep Available"
waitForProcess "$wait_time" "$sleep_time" "$cmd"
# Create Persistent Volume Claim
tmp_pvc_yaml=$(mktemp --tmpdir block_persistent_vol.XXXXX.yaml)
sed -e "s|CAPACITY|${vol_capacity}|" volume/block-loop-pvc.yaml > "$tmp_pvc_yaml"
kubectl create -f "$tmp_pvc_yaml"
# Create Workload using Volume
tmp_pod_yaml=$(mktemp --tmpdir pod-pv.XXXXX.yaml)
sed -e "s|DEVICE_PATH|${ctr_dev_path}|" "${pod_config_dir}/${pod_name}.yaml" > "$tmp_pod_yaml"
kubectl create -f "$tmp_pod_yaml"
kubectl wait --for condition=ready --timeout=$timeout "pod/${pod_name}"
# Verify persistent volume claim is bound
kubectl get "pvc/${volume_claim}" | grep "Bound"
# make fs, mount device and write on it
kubectl exec "$pod_name" -- sh -c "mkfs.ext4 $ctr_dev_path"
ctr_mount_path="/mnt"
ctr_message="Hello World"
ctr_file="${ctr_mount_path}/file.txt"
kubectl exec "$pod_name" -- sh -c "mount $ctr_dev_path $ctr_mount_path"
kubectl exec "$pod_name" -- sh -c "echo $ctr_message > $ctr_file"
kubectl exec "$pod_name" -- sh -c "grep '$ctr_message' $ctr_file"
}
teardown() {
# Debugging information
kubectl describe "pod/$pod_name"
# Delete k8s resources
kubectl delete pod "$pod_name"
kubectl delete pvc "$volume_claim"
kubectl delete pv "$volume_name"
kubectl delete storageclass local-storage
# Delete temporary yaml files
rm -f "$tmp_pv_yaml"
rm -f "$tmp_pvc_yaml"
rm -f "$tmp_pod_yaml"
# Remove image and loop device
exec_host "$node" sudo losetup -d "$loop_dev"
exec_host "$node" rm -f "$tmp_disk_image"
}

View File

@ -42,6 +42,7 @@ else
"k8s-confidential.bats" \
"k8s-sealed-secret.bats" \
"k8s-attach-handlers.bats" \
"k8s-block-volume.bats" \
"k8s-caps.bats" \
"k8s-configmap.bats" \
"k8s-copy-file.bats" \

View File

@ -0,0 +1,22 @@
apiVersion: v1
kind: Pod
metadata:
name: pod-block-pv
spec:
terminationGracePeriodSeconds: 0
runtimeClassName: kata
containers:
- name: my-container
image: quay.io/libpod/ubuntu:latest
command: ["tail", "-f", "/dev/null"]
volumeDevices:
- devicePath: DEVICE_PATH
name: my-volume
imagePullPolicy: IfNotPresent
securityContext:
capabilities:
add: ["SYS_ADMIN"]
volumes:
- name: my-volume
persistentVolumeClaim:
claimName: block-loop-pvc

View File

@ -0,0 +1,22 @@
apiVersion: v1
kind: PersistentVolume
metadata:
name: block-loop-pv
spec:
capacity:
storage: CAPACITY
volumeMode: Block
accessModes:
- ReadWriteOnce
persistentVolumeReclaimPolicy: Retain
storageClassName: local-storage
local:
path: LOOP_DEVICE
nodeAffinity:
required:
nodeSelectorTerms:
- matchExpressions:
- key: kubernetes.io/hostname
operator: In
values:
- HOSTNAME

View File

@ -0,0 +1,12 @@
kind: PersistentVolumeClaim
apiVersion: v1
metadata:
name: block-loop-pvc
spec:
accessModes:
- ReadWriteOnce
storageClassName: local-storage
volumeMode: Block
resources:
requests:
storage: CAPACITY

View File

@ -0,0 +1,6 @@
kind: StorageClass
apiVersion: storage.k8s.io/v1
metadata:
name: local-storage
provisioner: kubernetes.io/no-provisioner
volumeBindingMode: WaitForFirstConsumer