summaryrefslogtreecommitdiff
path: root/jstests/core/geo_s2indexoldformat.js
blob: 4ed0afba8ddd7de1f93b53b0a74e41ca0aded5fe (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
// 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]]}}});
});