0
0
mirror of https://github.com/mongodb/mongo.git synced 2024-11-24 16:46:00 +01:00
mongodb/jstests/noPassthrough/server_status.js

43 lines
1.8 KiB
JavaScript

// Checks storage-engine specific sections of db.severStatus() output.
(function() {
'use strict';
// 'backgroundFlushing' is mmapv1-specific.
var mongo = MongoRunner.runMongod({smallfiles: ""});
var testDB = mongo.getDB('test');
var serverStatus = assert.commandWorked(testDB.serverStatus());
if (serverStatus.storageEngine.name == 'mmapv1') {
assert(serverStatus.backgroundFlushing,
'mmapv1 db.serverStatus() result must contain backgroundFlushing document: ' +
tojson(serverStatus));
} else {
assert(!serverStatus.backgroundFlushing,
'Unexpected backgroundFlushing document in non-mmapv1 db.serverStatus() result: ' +
tojson(serverStatus));
}
MongoRunner.stopMongod(mongo);
// 'dur' is mmapv1-specific and should only be generated when journaling is enabled.
mongo = MongoRunner.runMongod({smallfiles: "", journal: ""});
testDB = mongo.getDB('test');
serverStatus = assert.commandWorked(testDB.serverStatus());
if (serverStatus.storageEngine.name == 'mmapv1') {
assert(
serverStatus.dur,
'mmapv1 db.serverStatus() result must contain "dur" document: ' + tojson(serverStatus));
} else {
assert(!serverStatus.dur,
'Unexpected "dur" document in non-mmapv1 db.serverStatus() result: ' +
tojson(serverStatus));
}
MongoRunner.stopMongod(mongo);
mongo = MongoRunner.runMongod({smallfiles: "", nojournal: ""});
testDB = mongo.getDB('test');
serverStatus = assert.commandWorked(testDB.serverStatus());
assert(!serverStatus.dur,
'Unexpected "dur" document in db.serverStatus() result when journaling is disabled: ' +
tojson(serverStatus));
MongoRunner.stopMongod(mongo);
}());