mirror of
https://github.com/kata-containers/kata-containers.git
synced 2025-06-19 20:24:35 +00:00
Share a single test script variable for both: - Allowing a command to be executed using Policy settings. - Executing that command using "kubectl exec". Fixes: #10014 Signed-off-by: Dan Mihai <dmihai@microsoft.com>
115 lines
3.1 KiB
Bash
115 lines
3.1 KiB
Bash
#!/usr/bin/env bats
|
|
#
|
|
# Copyright (c) 2019 Intel Corporation
|
|
#
|
|
# SPDX-License-Identifier: Apache-2.0
|
|
#
|
|
|
|
load "${BATS_TEST_DIRNAME}/../../common.bash"
|
|
load "${BATS_TEST_DIRNAME}/tests_common.sh"
|
|
|
|
setup() {
|
|
get_pod_config_dir
|
|
file_name="file.txt"
|
|
content="Hello"
|
|
}
|
|
|
|
@test "Copy file in a pod" {
|
|
# Create pod config YAML file.
|
|
pod_name="pod-copy-file-from-host"
|
|
ctr_name="ctr-copy-file-from-host"
|
|
|
|
pod_config=$(mktemp --tmpdir pod_config.XXXXXX.yaml)
|
|
cp "$pod_config_dir/busybox-template.yaml" "$pod_config"
|
|
sed -i "s/POD_NAME/$pod_name/" "$pod_config"
|
|
sed -i "s/CTR_NAME/$ctr_name/" "$pod_config"
|
|
|
|
# Add policy to the YAML file.
|
|
policy_settings_dir="$(create_tmp_policy_settings_dir "${pod_config_dir}")"
|
|
allowed_requests=(
|
|
"CloseStdinRequest"
|
|
"ReadStreamRequest"
|
|
"WriteStreamRequest"
|
|
)
|
|
add_requests_to_policy_settings "${policy_settings_dir}" "${allowed_requests[@]}"
|
|
add_copy_from_host_to_policy_settings "${policy_settings_dir}"
|
|
|
|
cat_command="cat /tmp/$file_name"
|
|
exec_command=(sh -c "${cat_command}")
|
|
add_exec_to_policy_settings "${policy_settings_dir}" "${exec_command[@]}"
|
|
|
|
auto_generate_policy "${policy_settings_dir}" "${pod_config}"
|
|
|
|
# Create pod
|
|
kubectl create -f "${pod_config}"
|
|
|
|
# Check pod creation
|
|
kubectl wait --for=condition=Ready --timeout=$timeout pod $pod_name
|
|
|
|
# Create a file
|
|
echo "$content" > "$file_name"
|
|
|
|
# Copy file into a pod
|
|
kubectl cp "$file_name" $pod_name:/tmp
|
|
|
|
# Print environment variables
|
|
kubectl exec $pod_name -- "${exec_command[@]}" | grep $content
|
|
}
|
|
|
|
@test "Copy from pod to host" {
|
|
# Create pod config YAML file.
|
|
pod_name="pod-copy-file-to-host"
|
|
ctr_name="ctr-copy-file-to-host"
|
|
|
|
pod_config=$(mktemp --tmpdir pod_config.XXXXXX.yaml)
|
|
cp "$pod_config_dir/busybox-template.yaml" "$pod_config"
|
|
sed -i "s/POD_NAME/$pod_name/" "$pod_config"
|
|
sed -i "s/CTR_NAME/$ctr_name/" "$pod_config"
|
|
|
|
# Add policy to the YAML file.
|
|
policy_settings_dir="$(create_tmp_policy_settings_dir "${pod_config_dir}")"
|
|
add_requests_to_policy_settings "${policy_settings_dir}" "ReadStreamRequest"
|
|
add_copy_from_guest_to_policy_settings "${policy_settings_dir}" "/tmp/file.txt"
|
|
|
|
guest_command="cd /tmp && echo $content > $file_name"
|
|
exec_command=(sh -c "${guest_command}")
|
|
add_exec_to_policy_settings "${policy_settings_dir}" "${exec_command[@]}"
|
|
|
|
auto_generate_policy "${policy_settings_dir}" "${pod_config}"
|
|
|
|
# Create pod
|
|
kubectl create -f "${pod_config}"
|
|
|
|
# Check pod creation
|
|
kubectl wait --for=condition=Ready --timeout=$timeout pod $pod_name
|
|
|
|
kubectl logs "$pod_name" || true
|
|
kubectl describe pod "$pod_name" || true
|
|
kubectl get pods --all-namespaces
|
|
|
|
# Create a file in the pod
|
|
kubectl exec "$pod_name" -- "${exec_command[@]}"
|
|
|
|
kubectl logs "$pod_name" || true
|
|
kubectl describe pod "$pod_name" || true
|
|
kubectl get pods --all-namespaces
|
|
|
|
# Copy file from pod to host
|
|
kubectl cp "$pod_name":/tmp/"$file_name" "$file_name"
|
|
|
|
# Verify content
|
|
cat "$file_name" | grep "$content"
|
|
}
|
|
|
|
teardown() {
|
|
# Debugging information
|
|
kubectl describe "pod/$pod_name"
|
|
|
|
rm -f "$file_name"
|
|
kubectl delete pod "$pod_name"
|
|
|
|
rm -f "$pod_config"
|
|
|
|
delete_tmp_policy_settings_dir "${policy_settings_dir}"
|
|
}
|