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
|
// test renameCollection with auth
port = allocatePorts( 1 )[ 0 ];
baseName = "jstests_rename_auth";
m = startMongod( "--auth", "--port", port, "--dbpath", MongoRunner.dataPath + baseName, "--nohttpinterface" );
db1 = m.getDB( baseName )
db2 = m.getDB( baseName + '_other' )
admin = m.getDB( 'admin' )
// Setup initial data
admin.addUser({user:'admin', pwd: 'password', roles: jsTest.adminUserRoles});
admin.auth('admin', 'password')
db1.addUser({user: "foo", pwd: "bar", roles: jsTest.basicUserRoles});
db2.addUser({user: "bar", pwd: "foo", roles: jsTest.basicUserRoles});
printjson(db1.a.count());
db1.a.save({});
assert.eq(db1.a.count(), 1);
admin.logout();
// can't run same db w/o auth
assert.commandFailed( admin.runCommand({renameCollection:db1.a.getFullName(), to: db1.b.getFullName()}) );
// can run same db with auth
db1.auth('foo', 'bar')
assert.commandWorked( admin.runCommand({renameCollection:db1.a.getFullName(), to: db1.b.getFullName()}) );
// can't run diff db w/o auth
assert.commandFailed( admin.runCommand({renameCollection:db1.b.getFullName(), to: db2.a.getFullName()}) );
// can run diff db with auth
db2.auth('bar', 'foo');
assert.commandWorked( admin.runCommand({renameCollection:db1.b.getFullName(), to: db2.a.getFullName()}) );
// test post conditions
assert.eq(db1.a.count(), 0);
assert.eq(db1.b.count(), 0);
assert.eq(db2.a.count(), 1);
|