File: index_bigkeys.js

package info (click to toggle)
mongodb 1%3A2.4.10-5
  • links: PTS, VCS
  • area: main
  • in suites: jessie-kfreebsd
  • size: 82,464 kB
  • sloc: cpp: 740,225; ansic: 152,098; sh: 13,820; python: 11,864; makefile: 1,012; perl: 922; pascal: 617; java: 452; lisp: 222; asm: 174
file content (78 lines) | stat: -rwxr-xr-x 1,419 bytes parent folder | download | duplicates (4)
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
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78

t = db.bigkeysidxtest;

var keys = [1, 2, 3, 4, 5, 6, 7, 8, 9, 10];

var str = "aaaabbbbccccddddeeeeffffgggghhhh";
str = str + str;

for (var i = 2; i < 10; i++) {
    keys[i] = str;
    str = str + str;
}
print(str.length);

var dir = 1;

function go() {
    if (dir == 1) {
        for (var i = 1; i < 10; i++) {
            t.insert({ _id: i, k: keys[i] });
        }
    }
    else {
        for (var i = 10; i >= 1; i--) {
            t.insert({ _id: i, k: keys[i] });
        }
    }
}

var expect = null;

var ok = true;

function check() {
    assert(t.validate().valid);

    var c = t.find({ k: /^a/ }).count();

    print("keycount:" + c);

    if (expect) {
        if (expect != c) {
            print("count of keys doesn't match expected count of : " + expect + " got: " + c);
            ok = false;
        }
    }
    else {
        expect = c;
    }

    //print(t.validate().result);
}

for (var pass = 1; pass <= 2; pass++) {
    print("pass:" + pass);

    t.drop();
    t.ensureIndex({ k: 1 });
    go();
    check(); // check incremental addition

    t.reIndex();
    check(); // check bottom up

    t.drop();
    go();
    t.ensureIndex({ k: 1 });
    check(); // check bottom up again without reindex explicitly

    t.drop();
    go();
    t.ensureIndex({ k: 1 }, { background: true });
    check(); // check background (which should be incremental)

    dir = -1;
}

assert(ok,"not ok");