// SERVER-533: Aggregation stage to randomly sample documents. import {assertErrorCode} from "jstests/aggregation/extras/utils.js"; import {assertDropAndRecreateCollection} from "jstests/libs/collection_drop_recreate.js"; const coll = assertDropAndRecreateCollection(db, "agg_sample"); coll.drop(); // Should return no results on a collection that doesn't exist. Should not crash. assert.eq(coll.aggregate([{$sample: {size: 10}}]).toArray(), []); const nItems = 3; for (let i = 0; i < nItems; i++) { assert.commandWorked(coll.insert({_id: i})); } [1, nItems, nItems + 1].forEach(function (size) { const results = coll.aggregate([{$sample: {size: size}}]).toArray(); assert.eq(results.length, Math.min(size, nItems)); }); // Multiple $sample stages are allowed. const results = coll.aggregate([{$sample: {size: nItems}}, {$sample: {size: 1}}]).toArray(); assert.eq(results.length, 1); // Invalid options. assertErrorCode(coll, [{$sample: "string"}], 28745); assertErrorCode(coll, [{$sample: {size: "string"}}], 28746); assertErrorCode(coll, [{$sample: {size: -1}}], 28747); assertErrorCode(coll, [{$sample: {unknownOpt: true}}], 28748); assertErrorCode( coll, [ { $sample: { /* no size */ }, }, ], 28749, ); // TODO(SERVER-94154): Remove version check here. const fcvDoc = db.adminCommand({getParameter: 1, featureCompatibilityVersion: 1}); if (MongoRunner.compareBinVersions(fcvDoc.featureCompatibilityVersion.version, "8.1") >= 0) { // Using a sample of size zero is only disallowed in some newer versions. assertErrorCode(coll, [{$sample: {size: 0}}], 28747); }