mirror of
https://github.com/kata-containers/kata-containers.git
synced 2025-10-21 11:58:41 +00:00
Auto-generate policy for k8s-shared-volume.bats. Fixes: #9096 Signed-off-by: Dan Mihai <dmihai@microsoft.com>
73 lines
2.0 KiB
Bash
73 lines
2.0 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
|
|
}
|
|
|
|
@test "Containers with shared volume" {
|
|
pod_name="test-shared-volume"
|
|
first_container_name="busybox-first-container"
|
|
second_container_name="busybox-second-container"
|
|
cmd="cat /tmp/pod-data"
|
|
yaml_file="${pod_config_dir}/pod-shared-volume.yaml"
|
|
|
|
# Add policy to the yaml file
|
|
policy_settings_dir="$(create_tmp_policy_settings_dir "${pod_config_dir}")"
|
|
|
|
exec_command="sh -c ${cmd}"
|
|
add_exec_to_policy_settings "${policy_settings_dir}" "${exec_command}"
|
|
|
|
add_requests_to_policy_settings "${policy_settings_dir}" "ReadStreamRequest"
|
|
auto_generate_policy "${policy_settings_dir}" "${yaml_file}"
|
|
|
|
# Create pod
|
|
kubectl create -f "${yaml_file}"
|
|
|
|
# Check pods
|
|
kubectl wait --for=condition=Ready --timeout=$timeout pod $pod_name
|
|
|
|
# Communicate containers
|
|
msg="Hello from the $second_container_name"
|
|
kubectl exec "$pod_name" -c "$first_container_name" -- sh -c "$cmd" | grep "$msg"
|
|
}
|
|
|
|
@test "initContainer with shared volume" {
|
|
pod_name="initcontainer-shared-volume"
|
|
last_container="last"
|
|
cmd='test $(cat /volume/initContainer) -lt $(cat /volume/container)'
|
|
yaml_file="${pod_config_dir}/initContainer-shared-volume.yaml"
|
|
|
|
# Add policy to the yaml file
|
|
policy_settings_dir="$(create_tmp_policy_settings_dir "${pod_config_dir}")"
|
|
|
|
exec_command="sh -c ${cmd}"
|
|
add_exec_to_policy_settings "${policy_settings_dir}" "${exec_command}"
|
|
|
|
add_requests_to_policy_settings "${policy_settings_dir}" "ReadStreamRequest"
|
|
auto_generate_policy "${policy_settings_dir}" "${yaml_file}"
|
|
|
|
# Create pod
|
|
kubectl create -f "${yaml_file}"
|
|
|
|
# Check pods
|
|
kubectl wait --for=condition=Ready --timeout=$timeout pod $pod_name
|
|
|
|
kubectl exec "$pod_name" -c "$last_container" -- sh -c "$cmd"
|
|
}
|
|
|
|
teardown() {
|
|
# Debugging information
|
|
kubectl describe "pod/$pod_name" || true
|
|
|
|
kubectl delete pod "$pod_name" || true
|
|
delete_tmp_policy_settings_dir "${policy_settings_dir}"
|
|
}
|