Files
mongo/jstests/core/geo_operator_crs.js

67 lines
1.9 KiB
JavaScript

//
// Tests that the correct CRSes are used for geo queries (based on input geometry)
//
var coll = db.geo_operator_crs;
coll.drop();
//
// Test 2dsphere index
//
assert.commandWorked(coll.ensureIndex({ geo : "2dsphere" }));
var legacyZeroPt = [0, 0];
var jsonZeroPt = { type : "Point", coordinates : [0, 0] };
var legacy90Pt = [90, 0];
var json90Pt = { type : "Point", coordinates : [90, 0] };
assert.writeOK(coll.insert({ geo : json90Pt }));
var earthRadiusMeters = 6378.1 * 1000;
var result = null;
result = coll.getDB().runCommand({ geoNear : coll.getName(),
near : legacyZeroPt,
spherical : true });
assert.commandWorked(result);
assert.close(result.results[0].dis, Math.PI / 2);
result = coll.getDB().runCommand({ geoNear : coll.getName(),
near : jsonZeroPt,
spherical : true });
assert.commandWorked(result);
assert.close(result.results[0].dis, (Math.PI / 2) * earthRadiusMeters);
assert.writeOK(coll.remove({}));
assert.commandWorked(coll.dropIndexes());
//
// Test 2d Index
//
assert.commandWorked(coll.ensureIndex({ geo : "2d" }));
assert.writeOK(coll.insert({ geo : legacy90Pt }));
result = coll.getDB().runCommand({ geoNear : coll.getName(),
near : legacyZeroPt,
spherical : true });
assert.commandWorked(result);
assert.close(result.results[0].dis, Math.PI / 2);
// GeoJSON not supported unless there's a 2dsphere index
//
// Test with a 2d and 2dsphere index
//
assert.commandWorked(coll.ensureIndex({ geo : "2dsphere" }));
result = coll.getDB().runCommand({ geoNear : coll.getName(),
near : jsonZeroPt,
spherical : true });
assert.commandWorked(result);
assert.close(result.results[0].dis, (Math.PI / 2) * earthRadiusMeters);