summaryrefslogtreecommitdiff
path: root/0086-cdi-test-case-and-gateway.patch
diff options
context:
space:
mode:
Diffstat (limited to '0086-cdi-test-case-and-gateway.patch')
-rw-r--r--0086-cdi-test-case-and-gateway.patch359
1 files changed, 359 insertions, 0 deletions
diff --git a/0086-cdi-test-case-and-gateway.patch b/0086-cdi-test-case-and-gateway.patch
new file mode 100644
index 0000000..42cef23
--- /dev/null
+++ b/0086-cdi-test-case-and-gateway.patch
@@ -0,0 +1,359 @@
+From 3fb6de60ecf10278a676a41f8d0c334d1f90d303 Mon Sep 17 00:00:00 2001
+From: liuxu <liuxu156@huawei.com>
+Date: Wed, 17 Apr 2024 18:02:48 +0800
+Subject: [PATCH 086/108] cdi:test case and gateway
+
+Signed-off-by: liuxu <liuxu156@huawei.com>
+---
+ CI/make-and-install.sh | 2 +-
+ CI/test_cases/container_cases/cdi_test.sh | 205 ++++++++++++++++++
+ .../criconfigs/container-config-cdi.json | 50 +++++
+ .../test_data/cdi_devices.json | 53 +++++
+ 4 files changed, 309 insertions(+), 1 deletion(-)
+ create mode 100755 CI/test_cases/container_cases/cdi_test.sh
+ create mode 100644 CI/test_cases/container_cases/criconfigs/container-config-cdi.json
+ create mode 100644 CI/test_cases/container_cases/test_data/cdi_devices.json
+
+diff --git a/CI/make-and-install.sh b/CI/make-and-install.sh
+index 9d4c5533..61281965 100755
+--- a/CI/make-and-install.sh
++++ b/CI/make-and-install.sh
+@@ -105,7 +105,7 @@ cd build
+ if [[ ${enable_gcov} -ne 0 ]]; then
+ cmake -DLIB_INSTALL_DIR=${builddir}/lib -DCMAKE_INSTALL_PREFIX=${builddir} -DCMAKE_INSTALL_SYSCONFDIR=${builddir}/etc -DCMAKE_BUILD_TYPE=Debug -DGCOV=ON -DENABLE_EMBEDDED=ON -DENABLE_COVERAGE=ON -DENABLE_CRI_API_V1=ON -DENABLE_CDI=ON -DENABLE_UT=ON -DENABLE_METRICS=ON -DENABLE_REMOTE_LAYER_STORE=ON -DENABLE_GRPC_REMOTE_CONNECT=ON ..
+ else
+- cmake -DLIB_INSTALL_DIR=${builddir}/lib -DCMAKE_INSTALL_PREFIX=${builddir} -DCMAKE_INSTALL_SYSCONFDIR=${builddir}/etc -DENABLE_EMBEDDED=ON -DENABLE_METRICS=ON -DENABLE_REMOTE_LAYER_STORE=ON -DENABLE_CRI_API_V1=ON -DENABLE_GRPC_REMOTE_CONNECT=ON ..
++ cmake -DLIB_INSTALL_DIR=${builddir}/lib -DCMAKE_INSTALL_PREFIX=${builddir} -DCMAKE_INSTALL_SYSCONFDIR=${builddir}/etc -DENABLE_EMBEDDED=ON -DENABLE_METRICS=ON -DENABLE_REMOTE_LAYER_STORE=ON -DENABLE_CRI_API_V1=ON -DENABLE_CDI=ON -DENABLE_GRPC_REMOTE_CONNECT=ON ..
+ fi
+ make -j $(nproc)
+ make install
+diff --git a/CI/test_cases/container_cases/cdi_test.sh b/CI/test_cases/container_cases/cdi_test.sh
+new file mode 100755
+index 00000000..dd7b1177
+--- /dev/null
++++ b/CI/test_cases/container_cases/cdi_test.sh
+@@ -0,0 +1,205 @@
++#!/bin/bash
++#
++# attributes: isulad cdi
++# concurrent: NA
++# spend time: 41
++
++#######################################################################
++##- Copyright (c) Huawei Technologies Co., Ltd. 2024. All rights reserved.
++# - iSulad licensed under the Mulan PSL v2.
++# - You can use this software according to the terms and conditions of the Mulan PSL v2.
++# - You may obtain a copy of Mulan PSL v2 at:
++# - http://license.coscl.org.cn/MulanPSL2
++# - THIS SOFTWARE IS PROVIDED ON AN "AS IS" BASIS, WITHOUT WARRANTIES OF ANY KIND, EITHER EXPRESS OR
++# - IMPLIED, INCLUDING BUT NOT LIMITED TO NON-INFRINGEMENT, MERCHANTABILITY OR FIT FOR A PARTICULAR
++# - PURPOSE.
++# - See the Mulan PSL v2 for more details.
++##- @Description:CI
++##- @Author: liuxu
++##- @Create: 2024-04-16
++#######################################################################
++
++source ../helpers.sh
++curr_path=$(dirname $(readlink -f "$0"))
++data_path=$(realpath $curr_path/criconfigs)
++pause_img_path=$(realpath $curr_path/test_data)
++cdi_static_dir="/etc/cdi"
++
++function do_pre()
++{
++ cp /etc/isulad/daemon.json /etc/isulad/daemon.bak
++ sed -i "s#\"pod-sandbox-image\": \"\"#\"pod-sandbox-image\": \"mirrorgooglecontainers/pause-amd64:3.0\"#g" /etc/isulad/daemon.json
++ sed -i "/\"cni-conf-dir\": \".*\"/a\ \ \ \ \"enable-cri-v1\": true," /etc/isulad/daemon.json
++ sed -i "/\"cni-conf-dir\": \".*\"/a\ \ \ \ \"enable-cdi\": true," /etc/isulad/daemon.json
++
++ check_valgrind_log
++ start_isulad_without_valgrind
++
++ isula load -i ${pause_img_path}/pause.tar
++ [[ $? -ne 0 ]] && msg_err "${FUNCNAME[0]}:${LINENO} - failed to load pause" && return ${FAILURE}
++
++ isula pull busybox
++ [[ $? -ne 0 ]] && msg_err "${FUNCNAME[0]}:${LINENO} - failed to pull busybox" && return ${FAILURE}
++
++ crictl images | grep "mirrorgooglecontainers/pause-amd64"
++ [[ $? -ne 0 ]] && msg_err "${FUNCNAME[0]}:${LINENO} - Failed to find mirrorgooglecontainers/pause-amd64 image" && return ${FAILURE}
++
++ return 0
++}
++
++function do_post()
++{
++ cp -f /etc/isulad/daemon.bak /etc/isulad/daemon.json
++ check_valgrind_log
++ start_isulad_without_valgrind
++}
++
++function verify_injected_vendor0() {
++ # check env
++ output=$(crictl exec --sync "$1" sh -c 'echo $VENDOR0')
++ [[ "$output" != "injected" ]] && msg_err "${FUNCNAME[0]}:${LINENO} - env check failed" && return ${FAILURE}
++
++ # check hooks
++ cat /tmp/cdi_hook_test.log | grep "prestart"
++ [[ $? -ne 0 ]] && msg_err "${FUNCNAME[0]}:${LINENO} - hook check failed" && return ${FAILURE}
++
++ # check mounts
++ output=$(crictl exec --sync "$1" sh -c 'stat -c %a /tmp/cdi_mounts_test')
++ [[ "$output" != "755" ]] && msg_err "${FUNCNAME[0]}:${LINENO} - mount check failed" && return ${FAILURE}
++
++ return 0
++}
++
++function verify_injected_loop8() {
++ # check env
++ output=$(crictl exec --sync "$1" sh -c 'echo $LOOP8')
++ [[ "$output" != "CDI8" ]] && msg_err "${FUNCNAME[0]}:${LINENO} - env check failed" && return ${FAILURE}
++
++ # check device nodes
++ output=$(crictl exec --sync "$1" sh -c 'stat -c %a /dev/loop8')
++ [[ "$output" != "640" ]] && msg_err "${FUNCNAME[0]}:${LINENO} - device nodes check failed" && return ${FAILURE}
++ output=$(crictl exec --sync "$1" sh -c 'stat -c %t.%T /dev/loop8')
++ [[ "$output" != "7.8" ]] && msg_err "${FUNCNAME[0]}:${LINENO} - device nodes check failed" && return ${FAILURE}
++ output=$(crictl exec --sync "$1" sh -c 'stat -c %t.%T /dev/loop8c')
++ [[ "$output" != "7.b" ]] && msg_err "${FUNCNAME[0]}:${LINENO} - device nodes check failed" && return ${FAILURE}
++
++ # check mounts
++ output=$(crictl exec --sync "$1" sh -c 'stat -c %a /tmp/cdi_mounts_test_loop8')
++ [[ "$output" != "755" ]] && msg_err "${FUNCNAME[0]}:${LINENO} - mount check failed" && return ${FAILURE}
++
++ return 0
++}
++
++function verify_injected_loop9() {
++ # check env
++ output=$(crictl exec --sync "$1" sh -c 'echo $LOOP9')
++ [[ "$output" != "present" ]] && msg_err "${FUNCNAME[0]}:${LINENO} - env check failed" && return ${FAILURE}
++
++ # check device nodes
++ output=$(crictl exec --sync "$1" sh -c 'stat -c %a /dev/loop9')
++ [[ "$output" != "644" ]] && msg_err "${FUNCNAME[0]}:${LINENO} - device nodes check failed" && return ${FAILURE}
++ output=$(crictl exec --sync "$1" sh -c 'stat -c %t.%T /dev/loop9')
++ [[ "$output" != "7.9" ]] && msg_err "${FUNCNAME[0]}:${LINENO} - device nodes check failed" && return ${FAILURE}
++
++ return 0
++}
++
++function check_full_cdi()
++{
++ verify_injected_vendor0 $1
++ [[ $? -ne 0 ]] && msg_err "${FUNCNAME[0]}:${LINENO} - verify_injected_vendor0 failed" && return ${FAILURE}
++
++ verify_injected_loop8 $1
++ [[ $? -ne 0 ]] && msg_err "${FUNCNAME[0]}:${LINENO} - verify_injected_loop8 failed" && return ${FAILURE}
++
++ verify_injected_loop9 $1
++ [[ $? -ne 0 ]] && msg_err "${FUNCNAME[0]}:${LINENO} - verify_injected_loop9 failed" && return ${FAILURE}
++
++ return 0
++}
++
++function do_test_help()
++{
++ msg_info "cdi test starting..."
++
++ isula rm -f `isula ps -a -q`
++
++ sid=`crictl runp ${data_path}/$1`
++ [[ $? -ne 0 ]] && msg_err "${FUNCNAME[0]}:${LINENO} - Failed to run sandbox" && return ${FAILURE}
++
++ cid=`crictl create $sid ${data_path}/$2 ${data_path}/$1`
++ [[ $? -ne 0 ]] && msg_err "${FUNCNAME[0]}:${LINENO} - create container failed" && return ${FAILURE}
++
++ crictl start $cid
++ [[ $? -ne 0 ]] && msg_err "${FUNCNAME[0]}:${LINENO} - start container failed" && return ${FAILURE}
++
++ crictl stats
++ [[ $? -ne 0 ]] && msg_err "${FUNCNAME[0]}:${LINENO} - stats container failed" && return ${FAILURE}
++
++ check_full_cdi $cid
++ [[ $? -ne 0 ]] && msg_err "${FUNCNAME[0]}:${LINENO} - check cdi failed" && return ${FAILURE}
++
++ crictl stop $cid
++ [[ $? -ne 0 ]] && msg_err "${FUNCNAME[0]}:${LINENO} - stop container failed" && return ${FAILURE}
++
++ crictl rm $cid
++ [[ $? -ne 0 ]] && msg_err "${FUNCNAME[0]}:${LINENO} - rm container failed" && return ${FAILURE}
++
++ crictl stopp $sid
++ [[ $? -ne 0 ]] && msg_err "${FUNCNAME[0]}:${LINENO} - stop sandbox failed" && return ${FAILURE}
++
++ crictl rmp $sid
++ [[ $? -ne 0 ]] && msg_err "${FUNCNAME[0]}:${LINENO} - rm sandbox failed" && return ${FAILURE}
++
++ return 0
++}
++
++function do_test_full_cdi()
++{
++ if [ ! -d "$cdi_static_dir" ]; then
++ mkdir -p "$cdi_static_dir"
++ fi
++ cp -f ${pause_img_path}/cdi_devices.json ${cdi_static_dir}/cdi_devices.json
++
++ mkdir -p /tmp/cdi_mounts_test
++ cat > /tmp/cdi_mounts_test_loop8 << EOF
++origin data
++EOF
++ chmod 755 /tmp/cdi_mounts_test_loop8
++ mkdir -p /tmp/cdi_mounts_test_loop9
++
++ mknod /dev/loop8 b 7 8
++ mknod /dev/loop9 b 7 9
++ mknod /dev/loop8c c 7 11
++
++ cat > /tmp/cdi_printargs.sh << EOF
++#!/bin/bash
++echo "\$(date +'%Y-%m-%d %H:%M:%S') Input parameter: \$1 \$2" >> /tmp/cdi_hook_test.log
++EOF
++ chmod 755 /tmp/cdi_printargs.sh
++
++ do_test_help "sandbox-config.json" "container-config-cdi.json" || ((ans++))
++
++ rm -f /tmp/cdi_printargs.sh
++ rm -f /tmp/cdi_hook_test.log
++ rm -f /dev/loop8
++ rm -f /dev/loop9
++ rm -f /dev/loop8c
++
++ rm -f ${cdi_static_dir}/cdi_devices.json
++ rm -f /tmp/cdi_printargs
++ rmdir /tmp/cdi_mounts_test
++ rm -f /tmp/cdi_mounts_test_loop8
++ rmdir /tmp/cdi_mounts_test_loop9
++ rm -f /tmp/cdi_printargs.sh
++
++ return 0
++}
++
++declare -i ans=0
++
++do_pre || ((ans++))
++do_test_full_cdi || ((ans++))
++do_post
++
++show_result ${ans} "${curr_path}/${0}"
+diff --git a/CI/test_cases/container_cases/criconfigs/container-config-cdi.json b/CI/test_cases/container_cases/criconfigs/container-config-cdi.json
+new file mode 100644
+index 00000000..b9805c8a
+--- /dev/null
++++ b/CI/test_cases/container_cases/criconfigs/container-config-cdi.json
+@@ -0,0 +1,50 @@
++{
++ "metadata": {
++ "name": "haozi"
++ },
++ "image":{
++ "image": "busybox:latest"
++ },
++ "command": [
++ "/bin/sh",
++ "-c",
++ "i=0; while true; do echo \"$i: $(date)\"; i=$((i+1)); sleep 10; done"
++ ],
++ "labels": {
++ "filter_label_key": "filter_label_val"
++ },
++ "annotations": {
++ "extension.network.kubernetes.io/cni/instancename": "pod_instance_name",
++ "cdi.k8s.io/test": "vendor0.com/device=loop8,vendor0.com/device=loop9"
++ },
++ "CDI_Devices":[
++ { "Name": "vendor0.com/device=loop8" },
++ { "Name": "vendor0.com/device=loop9" }
++ ],
++ "mounts" : [
++ {
++ "container_path": "/tmp/contpath",
++ "host_path": "/tmp/hostpath",
++ "readonly": true,
++ "selinux_relabel": true,
++ "propagation": 0
++ },
++ {
++ "container_path": "/tmp/contpath2",
++ "host_path": "/tmp/hostpath2",
++ "readonly": false,
++ "selinux_relabel": false,
++ "propagation": 0
++ }
++ ],
++ "linux": {
++ "security_context": {
++ "namespace_options": {
++ "host_network": true,
++ "host_pid": false,
++ "host_ipc": false
++ }
++ }
++ },
++ "log_path": "cri_test.log"
++}
+diff --git a/CI/test_cases/container_cases/test_data/cdi_devices.json b/CI/test_cases/container_cases/test_data/cdi_devices.json
+new file mode 100644
+index 00000000..f7fe65d4
+--- /dev/null
++++ b/CI/test_cases/container_cases/test_data/cdi_devices.json
+@@ -0,0 +1,53 @@
++{
++ "cdiVersion": "0.6.0",
++ "kind": "vendor0.com/device",
++ "annotations":{
++ "cdi_annotation":"cdi_annotation_value"
++ },
++ "devices": [
++ {
++ "name": "loop8",
++ "annotations":{
++ "loop8_annotation":"loop8_annotation_value"
++ },
++ "containerEdits": {
++ "env": [
++ "LOOP8=CDI8",
++ "PATH=/usr/local/sbin:/usr/local/bin:/usr/sbin:/usr/bin:/sbin:/bin:/dev"
++ ],
++ "deviceNodes": [
++ {"path": "/dev/loop8", "type": "b", "fileMode": 416},
++ {"path": "/dev/loop8c", "type": "c"}
++ ],
++ "mounts": [
++ {"hostPath": "/tmp/cdi_mounts_test_loop8", "containerPath": "/tmp/cdi_mounts_test_loop8", "options": ["ro","nosuid","nodev","bind"]},
++ {"hostPath": "tmpfs", "containerPath": "/tmp/data", "type": "tmpfs", "options": ["nosuid","strictatime","mode=755","size=65536k"]}
++ ]
++ }
++ },{
++ "name": "loop9",
++ "containerEdits": {
++ "env":["LOOP9=present"],
++ "deviceNodes": [{
++ "path": "/dev/loop9", "type": "b", "major": 7, "minor": 9, "fileMode": 420
++ }
++ ]
++ }
++ }
++ ],
++ "containerEdits": {
++ "env": [
++ "VENDOR0=injected",
++ "BAR=BARVALUE1"
++ ],
++ "hooks": [
++ {"hookName": "prestart", "path": "/tmp/cdi_printargs.sh", "args":["prestart0", "prestart1"], "env":["prestartenv=value"]},
++ {"hookName": "prestart", "path": "/tmp/cdi_printargs.sh", "args":["prestart0", "prestart1"], "env":["prestartenv=value"]},
++ {"hookName": "poststart", "path": "/tmp/cdi_printargs.sh", "args":["poststart0", "poststart1"], "env":["poststartenv=value"]},
++ {"hookName": "poststop", "path": "/tmp/cdi_printargs.sh", "args":["poststop0", "poststop1"], "env":["poststopenv=value"]}
++ ],
++ "mounts": [
++ {"hostPath": "/tmp/cdi_mounts_test", "containerPath": "/tmp/cdi_mounts_test", "options": ["ro","nosuid","nodev","bind"]}
++ ]
++ }
++}
+\ No newline at end of file
+--
+2.25.1
+