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
|
// Make sure that the 2dsphere index can deal with non-GeoJSON points.
// 2dsphere does not accept legacy shapes, only legacy points.
t = db.geo_s2indexoldformat;
t.drop();
t.insert({geo: [40, 5], nonGeo: ["pointA"]});
t.insert({geo: [41.001, 6.001], nonGeo: ["pointD"]});
t.insert({geo: [41, 6], nonGeo: ["pointB"]});
t.insert({geo: [41, 6]});
t.insert({geo: {x: 40.6, y: 5.4}});
t.ensureIndex({geo: "2dsphere", nonGeo: 1});
res = t.find({"geo": {"$geoIntersects": {"$geometry": {x: 40, y: 5}}}});
assert.eq(res.count(), 1);
res = t.find({"geo": {"$geoIntersects": {"$geometry": [41, 6]}}});
assert.eq(res.count(), 2);
// We don't support legacy polygons in 2dsphere.
assert.writeError(t.insert({geo: [[40, 5], [40, 6], [41, 6], [41, 5]], nonGeo: ["somepoly"]}));
assert.writeError(
t.insert({geo: {a: {x: 40, y: 5}, b: {x: 40, y: 6}, c: {x: 41, y: 6}, d: {x: 41, y: 5}}}));
// Test "Can't canonicalize query: BadValue bad geo query" error.
assert.throws(function() {
t.findOne({"geo": {"$geoIntersects": {"$geometry": [[40, 5], [40, 6], [41, 6], [41, 5]]}}});
});
|