diff options
author | Geir Storli <geirst@verizonmedia.com> | 2021-07-07 16:00:16 +0200 |
---|---|---|
committer | GitHub <noreply@github.com> | 2021-07-07 16:00:16 +0200 |
commit | 43d170f56130e4dc3611e2f5a309883895f3e99d (patch) | |
tree | 65fe3cbad9adf360e1063217c5ccf4b22b158d62 /searchcore/src/tests/proton/server/disk_mem_usage_metrics/disk_mem_usage_metrics_test.cpp | |
parent | 16fc7951efc4fd82cc9c4ef7bae2a3c217795b5b (diff) | |
parent | 2f6ad74b23968f9543e598f65605e91a771a6371 (diff) |
Merge pull request #18563 from vespa-engine/toregge/adjust-proton-disk-mem-usage-metrics-reporting
Adjust reporting of disk and memory usage in proton.
Diffstat (limited to 'searchcore/src/tests/proton/server/disk_mem_usage_metrics/disk_mem_usage_metrics_test.cpp')
-rw-r--r-- | searchcore/src/tests/proton/server/disk_mem_usage_metrics/disk_mem_usage_metrics_test.cpp | 39 |
1 files changed, 39 insertions, 0 deletions
diff --git a/searchcore/src/tests/proton/server/disk_mem_usage_metrics/disk_mem_usage_metrics_test.cpp b/searchcore/src/tests/proton/server/disk_mem_usage_metrics/disk_mem_usage_metrics_test.cpp new file mode 100644 index 00000000000..569633c518b --- /dev/null +++ b/searchcore/src/tests/proton/server/disk_mem_usage_metrics/disk_mem_usage_metrics_test.cpp @@ -0,0 +1,39 @@ +// Copyright Verizon Media. Licensed under the terms of the Apache 2.0 license. See LICENSE in the project root. + +#include <vespa/searchcore/proton/server/disk_mem_usage_metrics.h> +#include <vespa/searchcore/proton/server/disk_mem_usage_state.h> +#include <vespa/vespalib/gtest/gtest.h> + + +using proton::DiskMemUsageMetrics; +using proton::DiskMemUsageState; +using proton::ResourceUsageState; + +bool +expect_metrics(double disk_usage, double disk_utilization, double memory_usage, double memory_utilization, const DiskMemUsageMetrics &dm_metrics) +{ + bool result = true; + EXPECT_DOUBLE_EQ(disk_usage, dm_metrics.get_disk_usage()) << (result = false, ""); + EXPECT_DOUBLE_EQ(disk_utilization, dm_metrics.get_disk_utilization()) << (result = false, ""); + EXPECT_DOUBLE_EQ(memory_usage, dm_metrics.get_memory_usage()) << (result = false, ""); + EXPECT_DOUBLE_EQ(memory_utilization, dm_metrics.get_memory_utilization()) << (result = false, ""); + return result; +} + +TEST(DiskMemUsageMetricsTest, default_value_is_zero) +{ + DiskMemUsageMetrics dm_metrics; + EXPECT_TRUE(expect_metrics(0.0, 0.0, 0.0, 0.0, dm_metrics)); +} + +TEST(DiskMemUsageMetricsTest, merging_uses_max) +{ + DiskMemUsageMetrics dm_metrics({ResourceUsageState(0.5, 0.4), ResourceUsageState(0.5, 0.3)}); + EXPECT_TRUE(expect_metrics(0.4, 0.8, 0.3, 0.6, dm_metrics)); + dm_metrics.merge({ResourceUsageState(0.4, 0.4), ResourceUsageState(0.5, 0.4)}); + EXPECT_TRUE(expect_metrics(0.4, 1.0, 0.4, 0.8, dm_metrics)); + dm_metrics.merge({ResourceUsageState(0.5, 0.4), ResourceUsageState(0.5, 0.3)}); + EXPECT_TRUE(expect_metrics(0.4, 1.0, 0.4, 0.8, dm_metrics)); +} + +GTEST_MAIN_RUN_ALL_TESTS() |