File: disk_reuse1.js

package info (click to toggle)
mongodb 1%3A3.2.11-2%2Bdeb9u1
  • links: PTS, VCS
  • area: main
  • in suites: stretch
  • size: 196,404 kB
  • sloc: cpp: 1,412,793; ansic: 504,961; python: 78,522; perl: 5,837; sh: 5,661; java: 4,202; makefile: 1,784; pascal: 617; xml: 176; asm: 128
file content (51 lines) | stat: -rw-r--r-- 1,042 bytes parent folder | download
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
load("jstests/libs/slow_weekly_util.js");
test = new SlowWeeklyMongod("conc_update");
db = test.getDB("test");
t = db.disk_reuse1;
t.drop();

N = 10000;

function k() {
    return Math.floor(Math.random() * N);
}

s = "";
while (s.length < 1024)
    s += "abc";

state = {};

var bulk = t.initializeUnorderedBulkOp();
for (var i = 0; i < N; i++) {
    bulk.insert({_id: i, s: s});
}
assert.writeOK(bulk.execute());

orig = t.stats();

t.remove({});

bulk = t.initializeUnorderedBulkOp();
for (i = 0; i < N; i++) {
    bulk.insert({_id: i, s: s});
}
assert.writeOK(bulk.execute());

assert.eq(orig.storageSize, t.stats().storageSize, "A");

for (j = 0; j < 100; j++) {
    for (i = 0; i < N; i++) {
        bulk = t.initializeUnorderedBulkOp();
        var r = Math.random();
        if (r > .5)
            bulk.find({_id: i}).remove();
        else
            bulk.find({_id: i}).upsert().updateOne({_id: i, s: s});
    }

    assert.writeOK(bulk.execute());
    assert.eq(orig.storageSize, t.stats().storageSize, "B" + j);
}

test.stop();