summaryrefslogtreecommitdiffstats
path: root/plugins/t/check_disk.t
diff options
context:
space:
mode:
authorLorenz Kästle <12514511+RincewindsHat@users.noreply.github.com>2025-03-31 22:18:19 +0200
committerLorenz Kästle <12514511+RincewindsHat@users.noreply.github.com>2025-03-31 22:18:19 +0200
commit24a50b9421050b3c49dd07eddc942934f66685ca (patch)
tree743d73d689f3b8ac5db49a18c1712b05470d7df3 /plugins/t/check_disk.t
parent1b0085c2e7196aa77d605e8cb1863064a8e5189c (diff)
downloadmonitoring-plugins-24a50b9421050b3c49dd07eddc942934f66685ca.tar.gz
check_disk: decrease precision to avoid false negatives with small measurement changes
Diffstat (limited to 'plugins/t/check_disk.t')
-rw-r--r--plugins/t/check_disk.t9
1 files changed, 8 insertions, 1 deletions
diff --git a/plugins/t/check_disk.t b/plugins/t/check_disk.t
index 1d0b9838..f07b2303 100644
--- a/plugins/t/check_disk.t
+++ b/plugins/t/check_disk.t
@@ -54,6 +54,10 @@ my @perfdata;
54@perfdata[0] = $result->{'mp_test_result'}->{'checks'}->[0]->{'checks'}->[0]->{'perfdata'}->[0]; 54@perfdata[0] = $result->{'mp_test_result'}->{'checks'}->[0]->{'checks'}->[0]->{'perfdata'}->[0];
55@perfdata[1] = $result->{'mp_test_result'}->{'checks'}->[1]->{'checks'}->[0]->{'perfdata'}->[0]; 55@perfdata[1] = $result->{'mp_test_result'}->{'checks'}->[1]->{'checks'}->[0]->{'perfdata'}->[0];
56 56
57# Decrease precision of numbers since the the fs might be modified between the two runs
58$perfdata[0]->{'value'}->{'value'} = int($perfdata[0]->{'value'}->{'value'} / 1000000);
59$perfdata[0]->{'value'}->{'value'} = int($perfdata[0]->{'value'}->{'value'} / 1000000);
60
57# Calculate avg_free free on mountpoint1 and mountpoint2 61# Calculate avg_free free on mountpoint1 and mountpoint2
58# because if you check in the middle, you should get different errors 62# because if you check in the middle, you should get different errors
59my $avg_free_percent = ceil(($free_percent_on_mp1+$free_percent_on_mp2)/2); 63my $avg_free_percent = ceil(($free_percent_on_mp1+$free_percent_on_mp2)/2);
@@ -144,8 +148,11 @@ cmp_ok( $result->return_code, "==", 0, "with JSON test format result should alwa
144 148
145# write comparison set for perfdata here, but in reversed order, maybe there is a smarter way 149# write comparison set for perfdata here, but in reversed order, maybe there is a smarter way
146my @perfdata2; 150my @perfdata2;
147@perfdata2[1] = $result->{'mp_test_result'}->{'checks'}->[0]->{'checks'}->[0]->{'perfdata'}->[0];
148@perfdata2[0] = $result->{'mp_test_result'}->{'checks'}->[1]->{'checks'}->[0]->{'perfdata'}->[0]; 151@perfdata2[0] = $result->{'mp_test_result'}->{'checks'}->[1]->{'checks'}->[0]->{'perfdata'}->[0];
152@perfdata2[1] = $result->{'mp_test_result'}->{'checks'}->[0]->{'checks'}->[0]->{'perfdata'}->[0];
153# Decrease precision of numbers since the the fs might be modified between the two runs
154$perfdata2[0]->{'value'}->{'value'} = int($perfdata[0]->{'value'}->{'value'} / 1000000);
155$perfdata2[0]->{'value'}->{'value'} = int($perfdata[0]->{'value'}->{'value'} / 1000000);
149is_deeply(\@perfdata, \@perfdata2, "perf data for both filesystems same when reversed"); 156is_deeply(\@perfdata, \@perfdata2, "perf data for both filesystems same when reversed");
150 157
151# Basic filesystem checks for sizes 158# Basic filesystem checks for sizes