blob: a3d9251af57272fd8848db7dbf6ec1ef9809d7e0 (
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
|
// @tags: [does_not_support_stepdowns, requires_non_retryable_commands]
// 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.
// 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;
}
|