summaryrefslogtreecommitdiff
path: root/jstests/core/geo_s2largewithin.js
blob: e1eed8a2e6a98db30b57b4b0cd714f24358de0bc (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
29
30
31
32
33
34
35
36
// If our $within is enormous, create a coarse covering for the search so it
// doesn't take forever.
t = db.geo_s2largewithin;
t.drop();
t.createIndex({geo: "2dsphere"});

testPoint = {
    name: "origin",
    geo: {type: "Point", coordinates: [0.0, 0.0]}
};

testHorizLine = {
    name: "horiz",
    geo: {type: "LineString", coordinates: [[-2.0, 10.0], [2.0, 10.0]]}
};

testVertLine = {
    name: "vert",
    geo: {type: "LineString", coordinates: [[10.0, -2.0], [10.0, 2.0]]}
};

t.insert(testPoint);
t.insert(testHorizLine);
t.insert(testVertLine);

// Test a poly that runs horizontally along the equator.

longPoly = {
    type: "Polygon",
    coordinates: [[[30.0, 1.0], [-30.0, 1.0], [-30.0, -1.0], [30.0, -1.0], [30.0, 1.0]]]
};

result = t.find({geo: {$geoWithin: {$geometry: longPoly}}});
assert.eq(result.itcount(), 1);
result = t.find({geo: {$geoWithin: {$geometry: longPoly}}});
assert.eq("origin", result[0].name);