summaryrefslogtreecommitdiff
path: root/jstests/core/evalb.js
blob: d92573eef1ca5750054bfa0921087607ae087e20 (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
42
43
44
45
46
47
48
49
50
51
52
// Check the return value of a db.eval function running a database query, and ensure the function's
// contents are logged in the profile log.
//
// @tags: [
//   does_not_support_stepdowns,
//   requires_eval_command,
//   requires_non_retryable_commands,
// ]

// Use a reserved database name to avoid a conflict in the parallel test suite.
var stddb = db;
var db = db.getSisterDB('evalb');

function profileCursor() {
    return db.system.profile.find({user: username + "@" + db.getName()});
}

function lastOp() {
    return profileCursor().sort({$natural: -1}).next();
}

try {
    username = 'jstests_evalb_user';
    db.dropUser(username);
    db.createUser({user: username, pwd: 'password', roles: jsTest.basicUserRoles});
    db.auth(username, 'password');

    t = db.evalb;
    t.drop();

    t.save({x: 3});

    assert.eq(3,
              db.eval(function() {
                  return db.evalb.findOne().x;
              }),
              'A');

    db.setProfilingLevel(2);

    assert.eq(3,
              db.eval(function() {
                  return db.evalb.findOne().x;
              }),
              'B');

    o = lastOp();
    assert(tojson(o).indexOf('findOne().x') > 0, 'C : ' + tojson(o));
} finally {
    db.setProfilingLevel(0);
    db = stddb;
}