From 59a7b889d90b9fca29f534982a3792fb37ea72f6 Mon Sep 17 00:00:00 2001 From: Chris Date: Tue, 27 Feb 2024 16:21:58 +0800 Subject: [PATCH] Fix flaky test_volume_metrics ref: 7626 Signed-off-by: Chris --- manager/integration/tests/test_metric.py | 24 +++++++++++++++++++++--- 1 file changed, 21 insertions(+), 3 deletions(-) diff --git a/manager/integration/tests/test_metric.py b/manager/integration/tests/test_metric.py index 5223c70abe..217fc24486 100644 --- a/manager/integration/tests/test_metric.py +++ b/manager/integration/tests/test_metric.py @@ -8,6 +8,7 @@ from common import client, core_api, volume_name # NOQA from common import delete_replica_processes +from common import check_volume_data from common import create_pv_for_volume from common import create_pvc_for_volume from common import create_snapshot @@ -194,6 +195,21 @@ def filter_metric_by_labels(metrics, labels): assert total_metrics["value"] >= 0.0 +def wait_for_metric_volume_actual_size(core_api, metric_name, metric_labels, actual_size): # NOQA + for _ in range(RETRY_COUNTS): + time.sleep(RETRY_INTERVAL) + + try: + check_metric(core_api, metric_name, + metric_labels, actual_size) + return + except AssertionError: + continue + + check_metric(core_api, metric_name, + metric_labels, actual_size) + + def wait_for_metric_count_all_nodes(client, core_api, metric_name, metric_labels, expected_count): # NOQA for _ in range(RETRY_COUNTS): time.sleep(RETRY_INTERVAL) @@ -271,7 +287,8 @@ def test_volume_metrics(client, core_api, volume_name, pvc_namespace): # NOQA volume = client.by_id_volume(volume_name) volume.attach(hostId=lht_hostId) volume = wait_for_volume_healthy(client, volume_name) - write_volume_random_data(volume) + data = write_volume_random_data(volume) + check_volume_data(volume, data) volume = client.by_id_volume(volume_name) actual_size = float(volume.controllers[0].actualSize) capacity_size = float(volume.size) @@ -284,8 +301,9 @@ def test_volume_metrics(client, core_api, volume_name, pvc_namespace): # NOQA } # check volume metric basic - check_metric(core_api, "longhorn_volume_actual_size_bytes", - metric_labels, actual_size) + wait_for_metric_volume_actual_size(core_api, + "longhorn_volume_actual_size_bytes", + metric_labels, actual_size) check_metric(core_api, "longhorn_volume_capacity_bytes", metric_labels, capacity_size) check_metric(core_api, "longhorn_volume_read_throughput",