From 536b044b202042fa87efad64046919959978ab55 Mon Sep 17 00:00:00 2001 From: Kate Goldenring Date: Wed, 23 Oct 2024 16:47:03 -0700 Subject: [PATCH] fix: only add device id to broker env vars suffix Signed-off-by: Kate Goldenring --- .../device_plugin_instance_controller.rs | 10 +++--- test/e2e/README.md | 16 ++++++++++ test/e2e/conftest.py | 4 +-- test/e2e/test_core.py | 31 +++++++++++++++---- 4 files changed, 48 insertions(+), 13 deletions(-) create mode 100644 test/e2e/README.md diff --git a/agent/src/plugin_manager/device_plugin_instance_controller.rs b/agent/src/plugin_manager/device_plugin_instance_controller.rs index 097321b3d..fa190e32c 100644 --- a/agent/src/plugin_manager/device_plugin_instance_controller.rs +++ b/agent/src/plugin_manager/device_plugin_instance_controller.rs @@ -405,7 +405,7 @@ impl InternalDevicePlugin for InstanceDevicePlugin { tonic::Status::unknown("Unable to claim slot") })?; } - container_responses.push(cdi_device_to_car(&self.instance_name, &self.device)); + container_responses.push(cdi_device_to_car(&self.device)); } Ok(tonic::Response::new(AllocateResponse { container_responses, @@ -413,7 +413,7 @@ impl InternalDevicePlugin for InstanceDevicePlugin { } } -fn cdi_device_to_car(instance_name: &str, device: &cdi::Device) -> ContainerAllocateResponse { +fn cdi_device_to_car(device: &cdi::Device) -> ContainerAllocateResponse { ContainerAllocateResponse { envs: device .container_edits @@ -421,11 +421,11 @@ fn cdi_device_to_car(instance_name: &str, device: &cdi::Device) -> ContainerAllo .iter() .map(|e| match e.split_once('=') { Some((k, v)) => ( - format!("{}_{}", k, instance_name.to_uppercase()), + format!("{}_{}", k, device.name.to_uppercase()), v.to_string(), ), None => ( - format!("{}_{}", e, instance_name.to_uppercase()), + format!("{}_{}", e, device.name.to_uppercase()), "".to_string(), ), }) @@ -672,7 +672,7 @@ impl InternalDevicePlugin for ConfigurationDevicePlugin { .get(&dev) .ok_or(tonic::Status::unknown("Invalid slot"))? .clone(); - container_responses.push(cdi_device_to_car(&dp.instance_name, &dp.device)); + container_responses.push(cdi_device_to_car(&dp.device)); dp.claim_slot( None, DeviceUsage::Configuration { diff --git a/test/e2e/README.md b/test/e2e/README.md new file mode 100644 index 000000000..de0641697 --- /dev/null +++ b/test/e2e/README.md @@ -0,0 +1,16 @@ +# Running E2E Tests Locally + +Reference the [Akri developer guide](https://docs.akri.sh/development/test-cases-workflow#run-the-tests-locally) for details on running locally. + +## Displaying Output +By default, pytest captures output. If you always want to disable output capturing when running pytest through poetry, you can set the `PYTEST_ADDOPTS` environment variable: + +```sh +PYTEST_ADDOPTS="-s" poetry run pytest -v | tee output.log +``` + +## Running a Specific Test +A specific test can be executed by specifying its file and name like so: +``` +poetry run pytest test_core.py::test_device_offline -vvv +``` \ No newline at end of file diff --git a/test/e2e/conftest.py b/test/e2e/conftest.py index 5cf56c547..faec82014 100644 --- a/test/e2e/conftest.py +++ b/test/e2e/conftest.py @@ -71,7 +71,7 @@ def install_akri(request, pytestconfig, akri_version): helm_install_command.extend( [ "--set", - "agent.allowDebugEcho=true,debugEcho.configuration.shared=false", + "agent.allowDebugEcho=true", ] ) if pytestconfig.getoption("--use-local"): @@ -90,7 +90,7 @@ def install_akri(request, pytestconfig, akri_version): ) helm_install_command.extend( [ - "--debug", + # "--debug", "--atomic", ] ) diff --git a/test/e2e/test_core.py b/test/e2e/test_core.py index a3b0e72fc..194737e66 100644 --- a/test/e2e/test_core.py +++ b/test/e2e/test_core.py @@ -52,7 +52,6 @@ def test_all_scheduled(akri_version, basic_config): assert_svc_present(basic_config, True, 2) assert_svc_present(basic_config, False, 1) - def test_device_offline(akri_version, basic_config): # Check we are in sane setup assert_akri_instances_present(akri_version, basic_config, 2) @@ -61,15 +60,36 @@ def test_device_offline(akri_version, basic_config): assert_svc_present(basic_config, False, 1) v1_core = kubernetes.client.CoreV1Api() - pods = v1_core.list_namespaced_pod( + broker_pods = v1_core.list_namespaced_pod( "default", - label_selector=f"app.kubernetes.io/name=akri-debug-echo-discovery", + label_selector="akri.sh/configuration=akri-debug-echo-foo", field_selector="status.phase=Running", ).items + print(f"Broker pods are: {broker_pods}") base_command = ["/bin/sh", "-c"] + for pod in broker_pods: + envs = kubernetes.stream.stream( + v1_core.connect_get_namespaced_pod_exec, + pod.metadata.name, + "default", + command="printenv", + stdout=True, + stdin=False, + stderr=False, + tty=False, + ) + # TODO: Check env var suffix is as expected + if "DEBUG_ECHO_DESCRIPTION" not in envs: + raise AssertionError(f"DEBUG_ECHO_DESCRIPTION env var not found in broker") + + dh_pods = v1_core.list_namespaced_pod( + "default", + label_selector=f"app.kubernetes.io/name=akri-debug-echo-discovery", + field_selector="status.phase=Running", + ).items command = "echo {} > /tmp/debug-echo-availability.txt" # Unplug the devices - for pod in pods: + for pod in dh_pods: kubernetes.stream.stream( v1_core.connect_get_namespaced_pod_exec, pod.metadata.name, @@ -85,7 +105,7 @@ def test_device_offline(akri_version, basic_config): assert_svc_present(basic_config, True, 0) assert_svc_present(basic_config, False, 0) # Plug them back - for pod in pods: + for pod in dh_pods: kubernetes.stream.stream( v1_core.connect_get_namespaced_pod_exec, pod.metadata.name, @@ -101,7 +121,6 @@ def test_device_offline(akri_version, basic_config): assert_svc_present(basic_config, True, 2) assert_svc_present(basic_config, False, 1) - def test_cleanup(akri_version, faker): with open(Path(__file__).parent / "yaml/debugEchoConfiguration.yaml") as f: body = yaml.safe_load(f)