blob: 2abacb977be7a703ca0ffad0a4047831e03082c0 (
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
49
50
51
52
53
54
55
56
57
58
59
60
61
62
|
/**
* Verifies that showRecordId() returns the ObjectId type for time-series collections.
*
* @tags: [
* assumes_no_implicit_collection_creation_after_drop,
* does_not_support_stepdowns,
* requires_fcv_49,
* requires_find_command,
* requires_getmore,
* ]
*/
(function() {
"use strict";
load("jstests/core/timeseries/libs/timeseries.js");
if (!TimeseriesTest.timeseriesCollectionsEnabled(db.getMongo())) {
jsTestLog("Skipping test because the time-series collection feature flag is disabled");
return;
}
const timeFieldName = "time";
const coll = db.timeseries_show_record_id;
coll.drop();
assert.commandWorked(db.createCollection(coll.getName(), {timeseries: {timeField: timeFieldName}}));
Random.setRandomSeed();
const numHosts = 10;
const hosts = TimeseriesTest.generateHosts(numHosts);
for (let i = 0; i < 100; i++) {
const host = TimeseriesTest.getRandomElem(hosts);
TimeseriesTest.updateUsages(host.fields);
assert.commandWorked(coll.insert({
measurement: "cpu",
time: ISODate(),
fields: host.fields,
tags: host.tags,
}));
}
function checkRecordId(documents) {
for (const document of documents) {
assert(document.hasOwnProperty("$recordId"));
assert(document["$recordId"].isObjectId);
}
}
// The time-series user view uses aggregation to build a representation of the data.
// showRecordId() is not support in aggregation.
const error = assert.throws(() => {
coll.find().showRecordId().toArray();
});
assert.commandFailedWithCode(error, ErrorCodes.InvalidPipelineOperator);
const bucketsColl = db.getCollection("system.buckets." + coll.getName());
checkRecordId(bucketsColl.find().showRecordId().toArray());
})();
|