forked from mongodb/mongo
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathlist_local_sessions.js
67 lines (54 loc) · 2.59 KB
/
list_local_sessions.js
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
// All tests for the $listLocalSessions aggregation stage.
(function() {
'use strict';
load('jstests/aggregation/extras/utils.js');
function runListLocalSessionsTest(mongod) {
assert(mongod);
const admin = mongod.getDB('admin');
const db = mongod.getDB("test");
const pipeline = [{'$listLocalSessions': {}}];
function listLocalSessions() {
return admin.aggregate(pipeline);
}
admin.createUser({user: 'admin', pwd: 'pass', roles: jsTest.adminUserRoles});
assert(admin.auth('admin', 'pass'));
db.createUser({user: 'user1', pwd: 'pass', roles: jsTest.basicUserRoles});
db.createUser({user: 'user2', pwd: 'pass', roles: jsTest.basicUserRoles});
admin.logout();
// Shouldn't be able to listLocalSessions when not logged in.
assertErrorCode(admin, pipeline, ErrorCodes.Unauthorized);
// Start a new session and capture its sessionId.
assert(db.auth('user1', 'pass'));
const myid = assert.commandWorked(db.runCommand({startSession: 1})).id.id;
assert(myid !== undefined);
// Ensure that the cache now contains the session.
const resultArray = assert.doesNotThrow(listLocalSessions).toArray();
assert.eq(resultArray.length, 1);
const cacheid = resultArray[0]._id.id;
const myuid = resultArray[0]._id.uid;
assert(cacheid !== undefined);
assert.eq(0, bsonWoCompare({x: cacheid}, {x: myid}));
// Try asking for the session by username.
function listMyLocalSessions() {
return admin.aggregate(
[{'$listLocalSessions': {users: [{user: "user1", db: "test"}]}}]);
}
const resultArrayMine = assert.doesNotThrow(listMyLocalSessions).toArray();
assert.eq(bsonWoCompare(resultArray, resultArrayMine), 0);
// Ensure that changing users hides the session.
assert(db.auth('user2', 'pass'));
const otherArray = assert.doesNotThrow(listLocalSessions).toArray();
assert.eq(otherArray.length, 0);
// Ensure that one user can not explicitly ask for another's sessions.
assertErrorCode(admin,
[{'$listLocalSessions': {users: [{user: "user1", db: "test"}]}}],
ErrorCodes.Unauthorized);
}
const mongod = MongoRunner.runMongod({auth: ""});
runListLocalSessionsTest(mongod);
MongoRunner.stopMongod(mongod);
const st =
new ShardingTest({shards: 1, mongos: 1, config: 1, other: {keyFile: 'jstests/libs/key1'}});
runListLocalSessionsTest(st.s0);
st.stop();
})();