From ba4b46a0b6cb337cbcab88ae1f7039bc54f93987 Mon Sep 17 00:00:00 2001 From: Mark Grimes Date: Thu, 19 Dec 2024 10:50:52 -0800 Subject: [PATCH] Fix up test to match reality of NFS client reporting. --- tests/api2/test_usage_reporting.py | 17 ++++++++++++----- 1 file changed, 12 insertions(+), 5 deletions(-) diff --git a/tests/api2/test_usage_reporting.py b/tests/api2/test_usage_reporting.py index 7b0d586d64bd2..fc6e3816cff6e 100644 --- a/tests/api2/test_usage_reporting.py +++ b/tests/api2/test_usage_reporting.py @@ -1,4 +1,5 @@ import pytest +import time from itertools import chain from middlewared.test.integration.assets.nfs import nfs_server from middlewared.test.integration.assets.ftp import ftp_server @@ -52,20 +53,26 @@ def test_gather_types(get_usage_sample): def test_nfs_reporting(get_usage_sample): - """ Confirm we are correctly reporting the number of connections """ - # Initial state should have NFSv[3,4] and no connections + """ Confirm we are correctly reporting the number of NFS connections """ + # NOTE: NFSv3 can be wildly inaccurate. Connections are recorded by mount requests. + # Connections get cleared by umount requests. Stale entries can easily accumulate. + # NFSv4 clients can be slow-ish to showup. + # Initial state should have NFSv[3,4] and possibly some stale NFSv3 connections from previous tests assert set(get_usage_sample['NFS']['enabled_protocols']) == set(["NFSV3", "NFSV4"]) - assert get_usage_sample['NFS']['num_clients'] == 0 - # Establish two connections nfs_path = f'/mnt/{pool_name}/test_nfs' with nfs_dataset("test_nfs"): with nfs_share(nfs_path): with nfs_server(): + # Wait a couple secs for clients to report in + time.sleep(2) + baseline_sample = call('usage.gather')['NFS']['num_clients'] + + # Establish a new connection. with SSH_NFS(truenas_server.ip, nfs_path, user=user, password=password, ip=truenas_server.ip): usage_sample = call('usage.gather') - assert usage_sample['NFS']['num_clients'] == 1 + assert usage_sample['NFS']['num_clients'] == baseline_sample + 1 def test_ftp_reporting(get_usage_sample):