blob: a125d2a3f89d44071324298605ac1a84b93d2631 (
plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
|
/**
* Tests running the delete command on a time-series collection closes the in-memory bucket.
* @tags: [
* does_not_support_stepdowns,
* does_not_support_transactions,
* ]
*/
(function() {
"use strict";
load("jstests/core/timeseries/libs/timeseries.js"); // For 'TimeseriesTest'.
load("jstests/libs/fixture_helpers.js"); // For 'FixtureHelpers'.
if (!TimeseriesTest.timeseriesUpdatesAndDeletesEnabled(db.getMongo())) {
jsTestLog("Skipping test because the time-series updates and deletes feature flag is disabled");
return;
}
if (FixtureHelpers.isMongos(db) &&
!TimeseriesTest.shardedTimeseriesUpdatesAndDeletesEnabled(db.getMongo())) {
jsTestLog(
"Skipping test because the sharded time-series updates and deletes feature flag is disabled");
return;
}
TimeseriesTest.run((insert) => {
const testDB = db.getSiblingDB(jsTestName());
assert.commandWorked(testDB.dropDatabase());
const coll = testDB.getCollection('t');
const timeFieldName = "time";
const metaFieldName = "tag";
const objA = {[timeFieldName]: ISODate("2021-01-01T01:00:00Z"), [metaFieldName]: "A"};
const objB = {[timeFieldName]: ISODate("2021-01-01T01:01:00Z"), [metaFieldName]: "A"};
assert.commandWorked(testDB.createCollection(
coll.getName(), {timeseries: {timeField: timeFieldName, metaField: metaFieldName}}));
assert.commandWorked(insert(coll, objA));
assert.eq(assert.commandWorked(testDB.runCommand(
{delete: coll.getName(), deletes: [{q: {[metaFieldName]: "A"}, limit: 0}]}))["n"],
1);
assert.commandWorked(insert(coll, [objB]));
const docs = coll.find({}, {_id: 0}).toArray();
assert.docEq(docs, [objB]);
assert(coll.drop());
});
})();
|