Files
mongo/jstests/libs/ftdc.js
Ernesto Rodriguez Reina 3a784ed846 SERVER-103968 Test diagnostic directory size is doubled on sharded (#35162)
GitOrigin-RevId: 3a882e7aa97111c6c524b3b9c2e485f13518ebb2
2025-04-23 14:13:22 +00:00

158 lines
6.4 KiB
JavaScript

/**
* Utility test functions for FTDC
*/
import {isClusterNode, isMongos} from "jstests/concurrency/fsm_workload_helpers/server_types.js";
import {FeatureFlagUtil} from "jstests/libs/feature_flag_util.js";
export function getParameter(adminDb, field) {
var q = {getParameter: 1};
q[field] = 1;
var ret = adminDb.runCommand(q);
return ret[field];
}
export function setParameter(adminDb, obj) {
let o = Object.extend({setParameter: 1}, obj, true);
return adminDb.runCommand(Object.extend({setParameter: 1}, obj));
}
/**
* Returns whether the FTDC file format should follow the new format or not.
*/
export function hasMultiserviceFTDCSchema(adminDb) {
return FeatureFlagUtil.isPresentAndEnabled(adminDb, "MultiServiceLogAndFTDCFormat") &&
(isMongos(adminDb) || isClusterNode(adminDb));
}
/**
* Verify that getDiagnosticData is working correctly.
*/
export function verifyGetDiagnosticData(adminDb, logData = true, assumeMultiserviceSchema = false) {
// We need to retry a few times if run this test immediately after mongod is started as FTDC may
// not have run yet.
var foundGoodDocument = false;
for (var i = 0; i < 60 && foundGoodDocument == false; ++i) {
var result = adminDb.runCommand("getDiagnosticData");
assert.commandWorked(result);
var data = result.data;
if (!data.hasOwnProperty("start")) {
// Wait a little longer for FTDC to start
jsTestLog("Running getDiagnosticData: " + tojson(result));
sleep(500);
} else {
// Check for a few common properties to ensure we got data
if (hasMultiserviceFTDCSchema(adminDb) || assumeMultiserviceSchema ||
TestData.testingReplicaSetEndpoint) {
const hasKnownData =
(data.hasOwnProperty("shard") && data.shard.hasOwnProperty("serverStatus")) ||
(data.hasOwnProperty("router") && data.router.hasOwnProperty("connPoolStats"));
assert(hasKnownData,
"does not have 'shard.serverStatus' nor 'router.connPoolStats' in '" +
tojson(data) + "'");
} else {
assert(data.hasOwnProperty("serverStatus"),
"does not have 'serverStatus' in '" + tojson(data) + "'");
}
assert(data.hasOwnProperty("end"), "does not have 'end' in '" + tojson(data) + "'");
foundGoodDocument = true;
if (logData) {
jsTestLog("Got good getDiagnosticData: " + tojson(result));
}
}
}
assert(foundGoodDocument,
"getDiagnosticData failed to return a non-empty command, is FTDC running?");
return data;
}
/**
* Validate all the common FTDC parameters are set correctly and can be manipulated.
*/
export function verifyCommonFTDCParameters(adminDb, isEnabled) {
// Are we running against MongoS?
var isMongos = ("isdbgrid" == adminDb.runCommand("ismaster").msg);
// Check the defaults are correct
//
function getparam(field) {
return getParameter(adminDb, field);
}
// Verify the defaults are as we documented them
assert.eq(getparam("diagnosticDataCollectionEnabled"), isEnabled);
assert.eq(getparam("diagnosticDataCollectionPeriodMillis"), 1000);
const diagnosticDataCollectionDirectorySizeMB =
getparam("diagnosticDataCollectionDirectorySizeMB");
const isShardedCluster = adminDb.system.version.findOne({_id: "shardIdentity"});
if (isShardedCluster &&
FeatureFlagUtil.isPresentAndEnabled(adminDb, "MultiServiceLogAndFTDCFormat") && !isMongos) {
assert.eq(diagnosticDataCollectionDirectorySizeMB, 500);
} else {
assert.eq(diagnosticDataCollectionDirectorySizeMB, 250);
}
assert.eq(getparam("diagnosticDataCollectionFileSizeMB"), 10);
assert.eq(getparam("diagnosticDataCollectionSamplesPerChunk"), 300);
assert.eq(getparam("diagnosticDataCollectionSamplesPerInterimUpdate"), 10);
function setparam(obj) {
return setParameter(adminDb, obj);
}
if (!isMongos) {
// The MongoS specific behavior for diagnosticDataCollectionEnabled is tested in
// ftdc_setdirectory.js.
assert.commandWorked(setparam({"diagnosticDataCollectionEnabled": 1}));
}
assert.commandWorked(setparam({"diagnosticDataCollectionPeriodMillis": 100}));
assert.commandWorked(setparam({"diagnosticDataCollectionDirectorySizeMB": 10}));
assert.commandWorked(setparam({"diagnosticDataCollectionFileSizeMB": 1}));
assert.commandWorked(setparam({"diagnosticDataCollectionSamplesPerChunk": 2}));
assert.commandWorked(setparam({"diagnosticDataCollectionSamplesPerInterimUpdate": 2}));
// Negative tests - set values below minimums
assert.commandFailed(setparam({"diagnosticDataCollectionPeriodMillis": 1}));
assert.commandFailed(setparam({"diagnosticDataCollectionDirectorySizeMB": 1}));
assert.commandFailed(setparam({"diagnosticDataCollectionSamplesPerChunk": 1}));
assert.commandFailed(setparam({"diagnosticDataCollectionSamplesPerInterimUpdate": 1}));
// Negative test - set file size bigger then directory size
assert.commandWorked(setparam({"diagnosticDataCollectionDirectorySizeMB": 10}));
assert.commandFailed(setparam({"diagnosticDataCollectionFileSizeMB": 100}));
// Negative test - set directory size less then file size
assert.commandWorked(setparam({"diagnosticDataCollectionDirectorySizeMB": 100}));
assert.commandWorked(setparam({"diagnosticDataCollectionFileSizeMB": 50}));
assert.commandFailed(setparam({"diagnosticDataCollectionDirectorySizeMB": 10}));
// Reset
assert.commandWorked(setparam({"diagnosticDataCollectionFileSizeMB": 10}));
assert.commandWorked(setparam(
{"diagnosticDataCollectionDirectorySizeMB": diagnosticDataCollectionDirectorySizeMB}));
assert.commandWorked(setparam({"diagnosticDataCollectionPeriodMillis": 1000}));
assert.commandWorked(setparam({"diagnosticDataCollectionSamplesPerChunk": 300}));
assert.commandWorked(setparam({"diagnosticDataCollectionSamplesPerInterimUpdate": 10}));
}
export function waitFailedToStart(pid, exitCode) {
assert.soon(function() {
return !checkProgram(pid).alive;
}, `Failed to wait for ${pid} to die`, 30 * 1000);
assert.eq(exitCode,
checkProgram(pid).exitCode,
`Failed to wait for ${pid} to die with exit code ${exitCode}`);
}