Files
mongo/jstests/sharding/now_variable_replset.js

89 lines
2.5 KiB
JavaScript

/**
* Tests for the $$NOW and $$CLUSTER_TIME system variable on a replica set.
*/
// @tags: [requires_find_command]
(function() {
"use strict";
var replTest = new ReplSetTest({name: "now_and_cluster_time", nodes: 1});
replTest.startSet();
replTest.initiate();
var db = replTest.getPrimary().getDB("test");
const coll = db[jsTest.name()];
coll.drop();
db["viewWithNow"].drop();
db["viewWithClusterTime"].drop();
const numdocs = 1000;
const bulk = coll.initializeUnorderedBulkOp();
for (let i = 0; i < numdocs; ++i) {
bulk.insert({_id: i});
}
assert.writeOK(bulk.execute());
assert.commandWorked(
db.createView("viewWithNow", coll.getName(), [{$addFields: {timeField: "$$NOW"}}]));
const viewWithNow = db["viewWithNow"];
assert.commandWorked(db.createView(
"viewWithClusterTime", coll.getName(), [{$addFields: {timeField: "$$CLUSTER_TIME"}}]));
const viewWithClusterTime = db["viewWithClusterTime"];
function runTests(query) {
const results = query().toArray();
assert.eq(results.length, numdocs);
// Make sure the values are the same for all documents
for (let i = 0; i < numdocs; ++i) {
assert.eq(results[0].timeField, results[i].timeField);
}
// Sleep for a while and then rerun.
sleep(3000);
const resultsLater = query().toArray();
assert.eq(resultsLater.length, numdocs);
// Later results should be later in time.
assert.lte(results[0].timeField, resultsLater[0].timeField);
}
function baseCollectionNow() {
return coll.aggregate([{$addFields: {timeField: "$$NOW"}}]);
}
function baseCollectionClusterTime() {
return coll.aggregate([{$addFields: {timeField: "$$CLUSTER_TIME"}}]);
}
function fromViewWithNow() {
return viewWithNow.find();
}
function fromViewWithClusterTime() {
return viewWithClusterTime.find();
}
function withExprNow() {
return viewWithNow.find({$expr: {$eq: ["$timeField", "$$NOW"]}});
}
function withExprClusterTime() {
return viewWithClusterTime.find({$expr: {$eq: ["$timeField", "$$CLUSTER_TIME"]}});
}
// $$NOW
runTests(baseCollectionNow);
runTests(fromViewWithNow);
runTests(withExprNow);
// $$CLUSTER_TIME
runTests(baseCollectionClusterTime);
runTests(fromViewWithClusterTime);
runTests(withExprClusterTime);
replTest.stopSet();
}());