Moved test jstest/[a-i].js -> jstests/core/ and made changes to comply with write command api
72 lines
2.8 KiB
JavaScript
72 lines
2.8 KiB
JavaScript
// See: SERVER-9240, SERVER-9401.
|
|
// s2 rejects shapes with duplicate adjacent points as invalid, but they are
|
|
// valid in GeoJSON. We store the duplicates, but internally remove them
|
|
// before indexing or querying.
|
|
t = db.geo_s2dupe_points
|
|
t.drop()
|
|
t.ensureIndex({geo: "2dsphere"})
|
|
|
|
function testDuplicates(shapeName, shapeWithDupes, shapeWithoutDupes) {
|
|
// insert a doc with dupes
|
|
assert.writeOK(t.insert(shapeWithDupes));
|
|
|
|
// duplicates are preserved when the document is fetched by _id
|
|
assert.eq(shapeWithDupes, t.findOne({_id: shapeName}));
|
|
assert.neq(shapeWithoutDupes, t.findOne({_id: shapeName}).geo);
|
|
|
|
// can query with $geoIntersects inserted doc using both the duplicated and de-duplicated docs
|
|
assert.eq(t.find({ geo: { $geoIntersects: { $geometry : shapeWithDupes.geo } } } ).itcount(), 1);
|
|
assert.eq(t.find({ geo: { $geoIntersects: { $geometry : shapeWithoutDupes } } } ).itcount(), 1);
|
|
|
|
// direct document equality in queries is preserved
|
|
assert.eq(t.find({ geo: shapeWithoutDupes} ).itcount(), 0);
|
|
assert.eq(t.find({ geo: shapeWithDupes.geo } ).itcount(), 1);
|
|
}
|
|
|
|
// LineString
|
|
var lineWithDupes = { _id: "line", geo: { type: "LineString",
|
|
coordinates: [ [40,5], [40,5], [ 40, 5], [41, 6], [41,6] ]
|
|
}
|
|
};
|
|
var lineWithoutDupes = { type: "LineString", coordinates: [ [40,5], [41,6] ] };
|
|
|
|
// Polygon
|
|
var polygonWithDupes = { _id: "poly", geo: { type: "Polygon",
|
|
coordinates: [
|
|
[ [-3.0, -3.0], [3.0, -3.0], [3.0, 3.0], [-3.0, 3.0], [-3.0, -3.0] ],
|
|
[ [-2.0, -2.0], [2.0, -2.0], [2.0, 2.0], [-2.0, 2.0], [-2.0, -2.0], [-2.0, -2.0] ]
|
|
] }
|
|
};
|
|
var polygonWithoutDupes = { type: "Polygon",
|
|
coordinates: [
|
|
[ [-3.0, -3.0], [3.0, -3.0], [3.0, 3.0], [-3.0, 3.0], [-3.0, -3.0] ],
|
|
[ [-2.0, -2.0], [2.0, -2.0], [2.0, 2.0], [-2.0, 2.0], [-2.0, -2.0] ]
|
|
]
|
|
};
|
|
|
|
// MultiPolygon
|
|
var multiPolygonWithDupes = { _id: "multi", geo: { type: "MultiPolygon", coordinates: [
|
|
[
|
|
[ [102.0, 2.0], [103.0, 2.0], [103.0, 2.0], [103.0, 3.0], [102.0, 3.0], [102.0, 2.0] ]
|
|
],
|
|
[
|
|
[ [100.0, 0.0], [101.0, 0.0], [101.0, 1.0], [101.0, 1.0], [100.0, 1.0], [100.0, 0.0] ],
|
|
[ [100.2, 0.2], [100.8, 0.2], [100.8, 0.8], [100.8, 0.8], [100.8, 0.8], [100.2, 0.8], [100.2, 0.2] ]
|
|
]
|
|
]
|
|
} };
|
|
var multiPolygonWithoutDupes = { type: "MultiPolygon", coordinates: [
|
|
[
|
|
[ [102.0, 2.0], [103.0, 2.0], [103.0, 3.0], [102.0, 3.0], [102.0, 2.0] ]
|
|
],
|
|
[
|
|
[ [100.0, 0.0], [101.0, 0.0], [101.0, 1.0], [100.0, 1.0], [100.0, 0.0] ],
|
|
[ [100.2, 0.2], [100.8, 0.2], [100.8, 0.8], [100.2, 0.8], [100.2, 0.2] ]
|
|
]
|
|
]
|
|
};
|
|
|
|
testDuplicates("line", lineWithDupes, lineWithoutDupes);
|
|
testDuplicates("poly", polygonWithDupes, polygonWithoutDupes);
|
|
testDuplicates("multi", multiPolygonWithDupes, multiPolygonWithoutDupes);
|