0
0
mirror of https://github.com/mongodb/mongo.git synced 2024-12-01 09:32:32 +01:00
mongodb/jstests/core/index8.js

66 lines
1.8 KiB
JavaScript

// Cannot implicitly shard accessed collections because of not being able to create unique index
// using hashed shard key pattern.
// @tags: [cannot_create_unique_index_when_using_hashed_shard_key, requires_fastcount]
// Test key uniqueness
t = db.jstests_index8;
t.drop();
t.ensureIndex({a: 1});
t.ensureIndex({b: 1}, true);
t.ensureIndex({c: 1}, [false, "cIndex"]);
checkIndexes = function(num) {
var indexes = t.getIndexes();
assert.eq(4, indexes.length);
var start = 0;
if (indexes[0].name == "_id_")
start = 1;
assert(!indexes[start].unique, "A" + num);
assert(indexes[start + 1].unique, "B" + num + " " + tojson(indexes[start + 1]));
assert(!indexes[start + 2].unique, "C" + num);
assert.eq("cIndex", indexes[start + 2].name, "D" + num);
};
checkIndexes(1);
t.reIndex();
checkIndexes(2);
t.save({a: 2, b: 1});
t.save({a: 2});
assert.eq(2, t.find().count());
t.save({b: 4});
t.save({b: 4});
assert.eq(3, t.find().count());
assert.eq(3, t.find().hint({c: 1}).toArray().length);
assert.eq(3, t.find().hint({b: 1}).toArray().length);
assert.eq(3, t.find().hint({a: 1}).toArray().length);
t.drop();
t.ensureIndex({a: 1, b: -1}, true);
t.save({a: 2, b: 3});
t.save({a: 2, b: 3});
t.save({a: 2, b: 4});
t.save({a: 1, b: 3});
assert.eq(3, t.find().count());
t.drop();
t.ensureIndex({a: 1}, true);
t.save({a: [2, 3]});
t.save({a: 2});
assert.eq(1, t.find().count());
t.drop();
t.ensureIndex({a: 1}, true);
t.save({a: 2});
t.save({a: [1, 2, 3]});
t.save({a: [3, 2, 1]});
assert.eq(1, t.find().sort({a: 1}).hint({a: 1}).toArray().length);
assert.eq(1, t.find().sort({a: -1}).hint({a: 1}).toArray().length);
assert.eq(t._indexSpec({x: 1}, true), t._indexSpec({x: 1}, [true]), "spec 1");
assert.eq(t._indexSpec({x: 1}, "eliot"), t._indexSpec({x: 1}, ["eliot"]), "spec 2");