~evarlast/ubuntu/utopic/mongodb/upstart-workaround-debian-bug-718702

« back to all changes in this revision

Viewing changes to jstests/covered_index_geo_2.js

  • Committer: Package Import Robot
  • Author(s): James Page, James Page, Robie Basak
  • Date: 2013-05-29 17:44:42 UTC
  • mfrom: (44.1.7 sid)
  • Revision ID: package-import@ubuntu.com-20130529174442-z0a4qmoww4y0t458
Tags: 1:2.4.3-1ubuntu1
[ James Page ]
* Merge from Debian unstable, remaining changes:
  - Enable SSL support:
    + d/control: Add libssl-dev to BD's.
    + d/rules: Enabled --ssl option.
    + d/mongodb.conf: Add example SSL configuration options.
  - d/mongodb-server.mongodb.upstart: Add upstart configuration.
  - d/rules: Don't strip binaries during scons build for Ubuntu.
  - d/control: Add armhf to target archs.
  - d/p/SConscript.client.patch: fixup install of client libraries.
  - d/p/0010-install-libs-to-usr-lib-not-usr-lib64-Closes-588557.patch:
    Install libraries to lib not lib64.
* Dropped changes:
  - d/p/arm-support.patch: Included in Debian.
  - d/p/double-alignment.patch: Included in Debian.
  - d/rules,control: Debian also builds with avaliable system libraries
    now.
* Fix FTBFS due to gcc and boost upgrades in saucy:
  - d/p/0008-ignore-unused-local-typedefs.patch: Add -Wno-unused-typedefs
    to unbreak building with g++-4.8.
  - d/p/0009-boost-1.53.patch: Fixup signed/unsigned casting issue.

[ Robie Basak ]
* d/p/0011-Use-a-signed-char-to-store-BSONType-enumerations.patch: Fixup
  build failure on ARM due to missing signed'ness of char cast.

Show diffs side-by-side

added added

removed removed

Lines of Context:
 
1
var coll = db.getCollection("covered_geo_2")
 
2
coll.drop()
 
3
 
 
4
coll.insert({_id : 1, loc1 : [ 5 , 5 ], type1 : "type1",
 
5
    loc2 : [ 5 , 5 ], type2 : 1})
 
6
coll.insert({_id : 2, loc1 : [ 6 , 6 ], type1 : "type2",
 
7
    loc2 : [ 5 , 5 ], type2 : 2})
 
8
coll.insert({_id : 3, loc1 : [ 7 , 7 ], type1 : "type3",
 
9
    loc2 : [ 5 , 5 ], type2 : 3})
 
10
 
 
11
coll.ensureIndex({loc1 : "2dsphere", type1 : 1});
 
12
coll.ensureIndex({type2: 1, loc2 : "2dsphere"});
 
13
 
 
14
var plan = coll.find({loc1 : [ 6 , 6 ]}, {loc1:1, type1:1, _id:0}).hint({loc1:"2dsphere", type1:1}).explain();
 
15
assert.eq(false, plan.indexOnly, "geo.2.1 - indexOnly should be false on a non covered query")
 
16
assert.neq(0, plan.nscannedObjects, "geo.2.1 - nscannedObjects should not be 0 for a non covered query")
 
17
 
 
18
var plan = coll.find({loc1 : [ 6 , 6 ]}, {type1:1, _id:0}).hint({loc1:"2dsphere", type1:1}).explain();
 
19
assert.eq(false, plan.indexOnly, "geo.2.2 - indexOnly should be false for a non covered query")
 
20
assert.neq(0, plan.nscannedObjects, "geo.2.2 - nscannedObjects should not be 0 for a non covered query")
 
21
 
 
22
// The test below should not be covered but is due to https://jira.mongodb.org/browse/SERVER-8621
 
23
var plan = coll.find({type2 : {$lt:3}}, {type2:1, loc2:1, _id:0}).hint({type2: 1, loc2:"2dsphere"}).explain();
 
24
assert.eq(true, plan.indexOnly, "geo.2.3 - indexOnly should be false for a non covered query")
 
25
assert.eq(0, plan.nscannedObjects, "geo.2.3 - nscannedObjects should notbe 0 for a non covered query")
 
26
 
 
27
var plan = coll.find({type2 : {$lt:3}}, {type2:1, _id:0}).hint({type2:1, loc2:"2dsphere"}).explain();
 
28
assert.eq(true, plan.indexOnly, "geo.2.4 - indexOnly should be true for a covered query")
 
29
assert.eq(0, plan.nscannedObjects, "geo.2.4 - nscannedObjects should be 0 for a covered query")
 
30
 
 
31
print("all tests passed")
 
 
b'\\ No newline at end of file'