summaryrefslogtreecommitdiff
path: root/jstests/core/geo_nearwithin.js
diff options
context:
space:
mode:
Diffstat (limited to 'jstests/core/geo_nearwithin.js')
-rw-r--r--jstests/core/geo_nearwithin.js27
1 files changed, 27 insertions, 0 deletions
diff --git a/jstests/core/geo_nearwithin.js b/jstests/core/geo_nearwithin.js
new file mode 100644
index 00000000000..6f38f5dd7d9
--- /dev/null
+++ b/jstests/core/geo_nearwithin.js
@@ -0,0 +1,27 @@
+// Test geoNear + $within.
+t = db.geo_nearwithin
+t.drop();
+
+points = 10
+for (var x = -points; x < points; x += 1) {
+ for (var y = -points; y < points; y += 1) {
+ t.insert({geo: [x, y]})
+ }
+}
+
+t.ensureIndex({ geo : "2d" })
+
+resNear = db.runCommand({geoNear : t.getName(), near: [0, 0], query: {geo: {$within: {$center: [[0, 0], 1]}}}})
+assert.eq(resNear.results.length, 5)
+resNear = db.runCommand({geoNear : t.getName(), near: [0, 0], query: {geo: {$within: {$center: [[0, 0], 0]}}}})
+assert.eq(resNear.results.length, 1)
+resNear = db.runCommand({geoNear : t.getName(), near: [0, 0], query: {geo: {$within: {$center: [[1, 0], 0.5]}}}})
+assert.eq(resNear.results.length, 1)
+resNear = db.runCommand({geoNear : t.getName(), near: [0, 0], query: {geo: {$within: {$center: [[1, 0], 1.5]}}}})
+assert.eq(resNear.results.length, 9)
+
+// We want everything distance >1 from us but <1.5
+// These points are (-+1, -+1)
+resNear = db.runCommand({geoNear : t.getName(), near: [0, 0], query: {$and: [{geo: {$within: {$center: [[0, 0], 1.5]}}},
+ {geo: {$not: {$within: {$center: [[0,0], 1]}}}}]}})
+assert.eq(resNear.results.length, 4)