mirror of
https://github.com/Icinga/icinga2.git
synced 2025-07-30 09:04:35 +02:00
PluginUtility::FormatPerfdata(): normalize UoMs if desired
This commit is contained in:
parent
83cfb84fe0
commit
ea5411a6e0
@ -176,7 +176,7 @@ Array::Ptr PluginUtility::SplitPerfdata(const String& perfdata)
|
|||||||
return new Array(std::move(result));
|
return new Array(std::move(result));
|
||||||
}
|
}
|
||||||
|
|
||||||
String PluginUtility::FormatPerfdata(const Array::Ptr& perfdata)
|
String PluginUtility::FormatPerfdata(const Array::Ptr& perfdata, bool normalize)
|
||||||
{
|
{
|
||||||
if (!perfdata)
|
if (!perfdata)
|
||||||
return "";
|
return "";
|
||||||
@ -192,10 +192,25 @@ String PluginUtility::FormatPerfdata(const Array::Ptr& perfdata)
|
|||||||
else
|
else
|
||||||
first = false;
|
first = false;
|
||||||
|
|
||||||
if (pdv.IsObjectType<PerfdataValue>())
|
if (pdv.IsObjectType<PerfdataValue>()) {
|
||||||
result << static_cast<PerfdataValue::Ptr>(pdv)->Format();
|
result << static_cast<PerfdataValue::Ptr>(pdv)->Format();
|
||||||
else
|
} else if (normalize) {
|
||||||
|
PerfdataValue::Ptr normalized;
|
||||||
|
|
||||||
|
try {
|
||||||
|
normalized = PerfdataValue::Parse(pdv);
|
||||||
|
} catch (const std::invalid_argument& ex) {
|
||||||
|
Log(LogDebug, "PerfdataValue") << ex.what();
|
||||||
|
}
|
||||||
|
|
||||||
|
if (normalized) {
|
||||||
|
result << normalized->Format();
|
||||||
|
} else {
|
||||||
|
result << pdv;
|
||||||
|
}
|
||||||
|
} else {
|
||||||
result << pdv;
|
result << pdv;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
return result.str();
|
return result.str();
|
||||||
|
@ -31,7 +31,7 @@ public:
|
|||||||
static std::pair<String, String> ParseCheckOutput(const String& output);
|
static std::pair<String, String> ParseCheckOutput(const String& output);
|
||||||
|
|
||||||
static Array::Ptr SplitPerfdata(const String& perfdata);
|
static Array::Ptr SplitPerfdata(const String& perfdata);
|
||||||
static String FormatPerfdata(const Array::Ptr& perfdata);
|
static String FormatPerfdata(const Array::Ptr& perfdata, bool normalize = false);
|
||||||
|
|
||||||
private:
|
private:
|
||||||
PluginUtility();
|
PluginUtility();
|
||||||
|
@ -143,6 +143,7 @@ add_boost_test(base
|
|||||||
icinga_perfdata/simple
|
icinga_perfdata/simple
|
||||||
icinga_perfdata/quotes
|
icinga_perfdata/quotes
|
||||||
icinga_perfdata/multiple
|
icinga_perfdata/multiple
|
||||||
|
icinga_perfdata/normalize
|
||||||
icinga_perfdata/uom
|
icinga_perfdata/uom
|
||||||
icinga_perfdata/warncritminmax
|
icinga_perfdata/warncritminmax
|
||||||
icinga_perfdata/ignore_invalid_warn_crit_min_max
|
icinga_perfdata/ignore_invalid_warn_crit_min_max
|
||||||
|
@ -43,6 +43,15 @@ BOOST_AUTO_TEST_CASE(multiple)
|
|||||||
BOOST_CHECK(str == "testA=123456 testB=123456");
|
BOOST_CHECK(str == "testA=123456 testB=123456");
|
||||||
}
|
}
|
||||||
|
|
||||||
|
BOOST_AUTO_TEST_CASE(normalize)
|
||||||
|
{
|
||||||
|
Array::Ptr pd = PluginUtility::SplitPerfdata("testA=2m;3;4;1;5 testB=2foobar");
|
||||||
|
BOOST_CHECK(pd->GetLength() == 2);
|
||||||
|
|
||||||
|
String str = PluginUtility::FormatPerfdata(pd, true);
|
||||||
|
BOOST_CHECK(str == "testA=120s;180;240;60;300 testB=2");
|
||||||
|
}
|
||||||
|
|
||||||
BOOST_AUTO_TEST_CASE(uom)
|
BOOST_AUTO_TEST_CASE(uom)
|
||||||
{
|
{
|
||||||
PerfdataValue::Ptr pv = PerfdataValue::Parse("test=123456B");
|
PerfdataValue::Ptr pv = PerfdataValue::Parse("test=123456B");
|
||||||
|
Loading…
x
Reference in New Issue
Block a user