summaryrefslogtreecommitdiff
path: root/jstests/core/distinct_index2.js
blob: d1b72565102174468b37f95d2bc0a200ec6d1968 (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
37
38
39
40
41
t = db.distinct_index2;
t.drop();

t.ensureIndex({a: 1, b: 1});
t.ensureIndex({c: 1});

// Uniformly distributed dataset.
// If we use a randomly generated dataset, we might not
// generate all the distinct values in the range [0, 10).
for (var a = 0; a < 10; a++) {
    for (var b = 0; b < 10; b++) {
        for (var c = 0; c < 10; c++) {
            t.insert({a: a, b: b, c: c});
        }
    }
}

correct = [];
for (i = 0; i < 10; i++)
    correct.push(i);

function check(field) {
    res = t.distinct(field);
    res = res.sort();
    assert.eq(correct, res, "check: " + field);

    if (field != "a") {
        res = t.distinct(field, {a: 1});
        res = res.sort();
        assert.eq(correct, res, "check 2: " + field);
    }
}

check("a");
check("b");
check("c");

// hashed index should produce same results.
t.dropIndexes();
t.ensureIndex({a: "hashed"});
check("a");