From 2d1e87f6c292b311fcb4f57564417e9d1e32f629 Mon Sep 17 00:00:00 2001 From: Jusuf Date: Mon, 18 Nov 2024 11:05:20 +0100 Subject: [PATCH 1/3] Update astarte-ctl-test file -Add device ID generation and registration for E2E tests -Introduce support for E2E_DEVICE_TEST_2 environment variable. Signed-off-by: Jusuf --- .github/workflows/astarte-ctl-test.yaml | 3 +++ tests/conftest.py | 4 +++- 2 files changed, 6 insertions(+), 1 deletion(-) diff --git a/.github/workflows/astarte-ctl-test.yaml b/.github/workflows/astarte-ctl-test.yaml index 34c82ed..e56e4b5 100644 --- a/.github/workflows/astarte-ctl-test.yaml +++ b/.github/workflows/astarte-ctl-test.yaml @@ -131,6 +131,9 @@ jobs: TOKEN=$(astartectl utils gen-jwt all-realm-apis) echo "E2E_JWT=$TOKEN" >> $GITHUB_ENV echo "E2E_DEVICE_TEST_1=ogmcilZpRDeDWwuNfJr0yA" >> $GITHUB_ENV + DEVICE_TEST_2=$(astartectl utils device-id generate-random) + echo "E2E_DEVICE_TEST_2=$DEVICE_TEST_2" >> $GITHUB_ENV + astartectl pairing agent register --compact-output -- "$DEVICE_TEST_2" - name: Setup python uses: actions/setup-python@v2 diff --git a/tests/conftest.py b/tests/conftest.py index 870ed8a..5f9c30a 100644 --- a/tests/conftest.py +++ b/tests/conftest.py @@ -15,9 +15,10 @@ def astarte_env_vars(): realm = os.environ.get("E2E_REALM") jwt = os.environ.get("E2E_JWT") device_test_1 = os.environ.get("E2E_DEVICE_TEST_1") + device_test_2 = os.environ.get("E2E_DEVICE_TEST_2") assert ( - astarte_url and realm and jwt + astarte_url and realm and jwt and device_test_1 and device_test_2 ), "Environment variables for Astarte setup are not properly configured." return { @@ -25,4 +26,5 @@ def astarte_env_vars(): "realm": realm, "jwt": jwt, "device_test_1": device_test_1, + "device_test_2": device_test_2, } From 2e1b8aa79aa4957137ae5b4fc0ec034fb481d507 Mon Sep 17 00:00:00 2001 From: Jusuf Date: Mon, 18 Nov 2024 11:31:38 +0100 Subject: [PATCH 2/3] Add tests for Astarte group managment - Add tests for creating and listing groups. - Add tests for adding, listing, and removing devices from groups. - Updated resources.py to include mygroup variable for group name. Signed-off-by: Jusuf --- .../device/test_app_engine_groups.py | 140 ++++++++++++++++++ tests/resources.py | 2 + 2 files changed, 142 insertions(+) create mode 100644 tests/app_engine/device/test_app_engine_groups.py diff --git a/tests/app_engine/device/test_app_engine_groups.py b/tests/app_engine/device/test_app_engine_groups.py new file mode 100644 index 0000000..df66ef9 --- /dev/null +++ b/tests/app_engine/device/test_app_engine_groups.py @@ -0,0 +1,140 @@ +# SPDX-FileCopyrightText: 2024 SECO Mind Srl +# +# SPDX-License-Identifier: Apache-2.0 + + +import subprocess + +from resources import mygroup + + +def test_app_engine_group_create(astarte_env_vars): + astarte_url = astarte_env_vars["astarte_url"] + realm = astarte_env_vars["realm"] + jwt = astarte_env_vars["jwt"] + device_test_1 = astarte_env_vars["device_test_1"] + + arg_list = [ + "astartectl", + "appengine", + "groups", + "create", + mygroup, + device_test_1, + "-t", + jwt, + "-u", + astarte_url, + "-r", + realm, + ] + + sample_data_result = subprocess.run(arg_list, capture_output=True, text=True) + assert sample_data_result.stdout.replace("\n", "") == "ok" + + +def test_app_engine_group_list(astarte_env_vars): + astarte_url = astarte_env_vars["astarte_url"] + realm = astarte_env_vars["realm"] + jwt = astarte_env_vars["jwt"] + + arg_list = [ + "astartectl", + "appengine", + "groups", + "list", + "-t", + jwt, + "-u", + astarte_url, + "-r", + realm, + ] + + sample_data_result = subprocess.run(arg_list, capture_output=True, text=True) + sample_data_result.stdout = _replace_brackets_from_string(sample_data_result.stdout) + assert sample_data_result.stdout in mygroup + + +def test_app_engine_group_devices_list(astarte_env_vars): + astarte_url = astarte_env_vars["astarte_url"] + realm = astarte_env_vars["realm"] + jwt = astarte_env_vars["jwt"] + device_test_1 = astarte_env_vars["device_test_1"] + + arg_list = [ + "astartectl", + "appengine", + "groups", + "devices", + "list", + mygroup, + "-t", + jwt, + "-u", + astarte_url, + "-r", + realm, + ] + + sample_data_result = subprocess.run(arg_list, capture_output=True, text=True) + sample_data_result.stdout = _replace_brackets_from_string(sample_data_result.stdout) + assert sample_data_result.stdout in device_test_1 + + +def test_app_engine_group_add_device(astarte_env_vars): + astarte_url = astarte_env_vars["astarte_url"] + realm = astarte_env_vars["realm"] + jwt = astarte_env_vars["jwt"] + device_test_2 = astarte_env_vars["device_test_2"] + + arg_list = [ + "astartectl", + "appengine", + "groups", + "devices", + "add", + mygroup, + device_test_2, + "-t", + jwt, + "-u", + astarte_url, + "-r", + realm, + ] + + sample_data_result = subprocess.run(arg_list, capture_output=True, text=True) + print(sample_data_result.stdout) + assert sample_data_result.stdout.replace("\n", "") == "ok" + + +def test_app_engine_group_remove_device(astarte_env_vars): + astarte_url = astarte_env_vars["astarte_url"] + realm = astarte_env_vars["realm"] + jwt = astarte_env_vars["jwt"] + device_test_2 = astarte_env_vars["device_test_2"] + + arg_list = [ + "astartectl", + "appengine", + "groups", + "devices", + "remove", + mygroup, + device_test_2, + "-t", + jwt, + "-u", + astarte_url, + "-r", + realm, + ] + + sample_data_result = subprocess.run(arg_list, capture_output=True, text=True) + print(sample_data_result.stdout) + assert sample_data_result.stdout.replace("\n", "") == "ok" + + +def _replace_brackets_from_string(input_string): + return input_string.replace("\n", "").replace("[", "").replace("]", "") diff --git a/tests/resources.py b/tests/resources.py index 1191ac5..7be362d 100644 --- a/tests/resources.py +++ b/tests/resources.py @@ -235,3 +235,5 @@ "test_attribute3": "test_attribute3=attribute3", "test_attribute4": "test_attribute4=attribute4", } + +mygroup = "test_group" From 3d5a8047025a218e38573e5c23b6bf87b20a99dd Mon Sep 17 00:00:00 2001 From: Jusuf Date: Wed, 20 Nov 2024 15:46:44 +0100 Subject: [PATCH 3/3] Update device stats test for new E2E device - Reflects the addition of a new device in the E2E environment Signed-off-by: Jusuf --- tests/app_engine/device/test_app_engine_device.py | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/tests/app_engine/device/test_app_engine_device.py b/tests/app_engine/device/test_app_engine_device.py index 4b16052..5d698b4 100644 --- a/tests/app_engine/device/test_app_engine_device.py +++ b/tests/app_engine/device/test_app_engine_device.py @@ -107,5 +107,5 @@ def test_app_engine_stats_device(astarte_env_vars): ] sample_data_result = subprocess.run(arg_list, capture_output=True, text=True) - except_output = "{TotalDevices:1 ConnectedDevices:0}\n" + except_output = "{TotalDevices:2 ConnectedDevices:0}\n" assert sample_data_result.stdout == except_output