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");
|