diff options
author | Adrian Gonzalez <adriangonzalezmontemayor@gmail.com> | 2023-04-28 12:57:33 +0000 |
---|---|---|
committer | Evergreen Agent <no-reply@evergreen.mongodb.com> | 2023-04-28 15:08:56 +0000 |
commit | f3f504d1bfa734c91163ab2e072d4caa7e358412 (patch) | |
tree | 68b04251b95a5246da1ea6d38a8b76d75fa2b80c /src/mongo/util/procparser_test.cpp | |
parent | 9dc2751661623af8c071f9f7ce9d9676a2f5469a (diff) | |
download | mongo-f3f504d1bfa734c91163ab2e072d4caa7e358412.tar.gz |
SERVER-45255 Capture Pressure Stall Information in FTDC for Linux hosts
Diffstat (limited to 'src/mongo/util/procparser_test.cpp')
-rw-r--r-- | src/mongo/util/procparser_test.cpp | 111 |
1 files changed, 111 insertions, 0 deletions
diff --git a/src/mongo/util/procparser_test.cpp b/src/mongo/util/procparser_test.cpp index 08db075dbf7..15890459dbf 100644 --- a/src/mongo/util/procparser_test.cpp +++ b/src/mongo/util/procparser_test.cpp @@ -120,6 +120,11 @@ StringMap toNestedStringMap(BSONObj& obj) { ASSERT_OK(procparser::parseProcSysFsFileNr(_key, _x, &builder)); \ auto obj = builder.obj(); \ auto stringMap = toStringMap(obj); +#define ASSERT_PARSE_PRESSURE(_x) \ + BSONObjBuilder builder; \ + ASSERT_OK(procparser::parseProcPressure(_x, &builder)); \ + auto obj = builder.obj(); \ + auto stringMap = toStringMap(obj); TEST(FTDCProcStat, TestStat) { @@ -934,5 +939,111 @@ TEST(FTDCProcSysFsFileNr, TestFile) { "/proc/non-existent-file", procparser::FileNrKey::kFileHandlesInUse, &builder)); } +TEST(FTDCProcPressure, TestSuccess) { + // Normal cases + { + ASSERT_PARSE_PRESSURE( + "some avg10=0.10 avg60=6.50 avg300=1.00 total=14\nfull avg10=2.30 " + "avg60=0.00 avg300=0.14 total=10"); + ASSERT(obj["some"]["totalMicros"].Double() == 14); + + ASSERT(obj["full"]["totalMicros"].Double() == 10); + } + { + ASSERT_PARSE_PRESSURE("some avg10=0.10 avg60=6.50 avg300=1.00 total=14"); + ASSERT(obj["some"]["totalMicros"].Double() == 14); + + ASSERT(!obj["full"]); + } + { + ASSERT_PARSE_PRESSURE( + "some avg10=0.10 avg60=6.50 avg300=1.00 total=14\nfull avg10=2.30 " + "avg60=0.00 avg300=0.14 total=10"); + ASSERT(obj["some"]["totalMicros"].Double() == 14); + + ASSERT(obj["full"]["totalMicros"].Double() == 10); + } +} + +TEST(FTDCProcPressure, TestFailure) { + // Failure cases + { + BSONObjBuilder builder; + ASSERT_NOT_OK(procparser::parseProcPressureFile("", "", &builder)); + } + + { + BSONObjBuilder builder; + ASSERT_NOT_OK( + procparser::parseProcPressureFile("cpu", "/proc/non-existent-file", &builder)); + } + + // 'total' is not found in the data given. + { + BSONObjBuilder builder; + ASSERT_NOT_OK( + procparser::parseProcPressure("some avg10=0.10 avg60=6.50 avg300=1.00", &builder)); + } + + // 'total' is not found in one of the rows. + { + BSONObjBuilder builder; + ASSERT_NOT_OK( + procparser::parseProcPressure("some avg10=0.10 avg60=6.50 avg300=1.00\nfull avg10=2.30 " + "avg60=0.00 avg300=0.14 total=10", + &builder)); + } + + // 'total' is not given a valid number value. + { + BSONObjBuilder builder; + ASSERT_NOT_OK(procparser::parseProcPressure( + "some avg10=0.10 avg60=6.50 avg300=1.00 total=invalid", &builder)); + } +} + +TEST(FTDCProcPressure, TestLocalPressureInfo) { + if (boost::filesystem::exists("/proc/pressure/cpu")) { + BSONObjBuilder builder; + + ASSERT_OK(procparser::parseProcPressureFile("cpu", "/proc/pressure/cpu", &builder)); + + BSONObj obj = builder.obj(); + ASSERT(obj.hasField("cpu")); + ASSERT(obj["cpu"]["some"]); + ASSERT(obj["cpu"]["some"]["totalMicros"]); + + ASSERT(!obj["cpu"]["full"]); + } + + if (boost::filesystem::exists("/proc/pressure/memory")) { + BSONObjBuilder builder; + + ASSERT_OK(procparser::parseProcPressureFile("memory", "/proc/pressure/memory", &builder)); + + BSONObj obj = builder.obj(); + ASSERT(obj.hasField("memory")); + ASSERT(obj["memory"]["some"]); + ASSERT(obj["memory"]["some"]["totalMicros"]); + + ASSERT(obj["memory"]["full"]); + ASSERT(obj["memory"]["full"]["totalMicros"]); + } + + if (boost::filesystem::exists("/proc/pressure/io")) { + BSONObjBuilder builder; + + ASSERT_OK(procparser::parseProcPressureFile("io", "/proc/pressure/io", &builder)); + + BSONObj obj = builder.obj(); + ASSERT(obj.hasField("io")); + ASSERT(obj["io"]["some"]); + ASSERT(obj["io"]["some"]["totalMicros"]); + + ASSERT(obj["io"]["full"]); + ASSERT(obj["io"]["full"]["totalMicros"]); + } +} + } // namespace } // namespace mongo |