This commit removes the geoNear command and moves its implementation into the aggregation framework. Users should use the aggregate command with a $geoNear stage. The implementation rewrite additionally removes the limit in the $geoNear aggregation stage. To limit the number of results, use a $limit stage.
33 lines
1.3 KiB
JavaScript
33 lines
1.3 KiB
JavaScript
/**
|
|
* Test that $near queries are disallowed in $match stages.
|
|
*/
|
|
(function() {
|
|
"use strict";
|
|
load("jstests/aggregation/extras/utils.js");
|
|
|
|
const coll = db.getCollection("no_near_in_match");
|
|
coll.drop();
|
|
|
|
// Create indexes that could satisfy various $near queries.
|
|
assert.commandWorked(coll.createIndex({point2d: "2d"}));
|
|
assert.commandWorked(coll.createIndex({point2dsphere: "2dsphere"}));
|
|
|
|
// Populate the collection so that successful queries can return at least one result.
|
|
assert.writeOK(coll.insert({point2d: [0.25, 0.35]}));
|
|
assert.writeOK(coll.insert({point2dsphere: [0.25, 0.35]}));
|
|
|
|
const nearQuery = {point2d: {$near: [0, 0]}};
|
|
const nearSphereQuery = {point2dsphere: {$nearSphere: [0, 0]}};
|
|
const geoNearQuery = {point2d: {$geoNear: [0, 0]}};
|
|
|
|
// Test that normal finds return a result.
|
|
assert.eq(1, coll.find(nearQuery).count());
|
|
assert.eq(1, coll.find(nearSphereQuery).count());
|
|
assert.eq(1, coll.find(geoNearQuery).count());
|
|
|
|
// Test that we refuse to run $match with a near query.
|
|
assertErrorCode(coll, {$match: nearQuery}, ErrorCodes.BadValue);
|
|
assertErrorCode(coll, {$match: nearSphereQuery}, ErrorCodes.BadValue);
|
|
assertErrorCode(coll, {$match: geoNearQuery}, ErrorCodes.BadValue);
|
|
}());
|