mirror of
				https://github.com/kata-containers/kata-containers.git
				synced 2025-10-22 12:29:49 +00:00 
			
		
		
		
	teardown() gets executed after each test case, so there is no need to clean-up before teardown. Fixes: #9072 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 -- sh -c "${cat_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" -- sh -c "$guest_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}"
 | |
| }
 |