-
Notifications
You must be signed in to change notification settings - Fork 51
/
Copy pathushuffle_mongo.py
76 lines (61 loc) · 2.03 KB
/
ushuffle_mongo.py
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
68
69
70
71
72
73
74
75
76
#!/usr/bin/env python
from distutils.log import warn as printf
from random import randrange as rand
from pymongo import MongoClient, errors
from ushuffle_dbU import DBNAME, randName, FIELDS, tformat, cformat
COLLECTION = 'users'
class MongoTest(object):
def __init__(self):
try:
self.cxn = MongoClient()
except errors.AutoReconnect:
raise RuntimeError()
self.db = self.cxn[DBNAME]
self.users = self.db[COLLECTION]
def insert(self):
self.users.insert(
dict(login=who, userid=uid, projid=rand(1, 5)) \
for who, uid in randName())
def update(self):
fr = rand(1, 5)
to = rand(1, 5)
i = -1
for i, user in enumerate(self.users.find({'projid': fr})):
self.users.update(user, {'$set': {'projid': to}})
return fr, to, i+1
def delete(self):
rm = rand(1, 5)
i = -1
for i, user in enumerate(self.users.find({'projid': rm})):
self.users.remove(user)
return rm, i+1
def dbDump(self):
printf("\n%s" % "".join(map(cformat, FIELDS)))
for user in self.users.find():
printf("".join(map(tformat, (user[k] for k in FIELDS))))
def finish(self):
self.cxn.close()
def main():
printf("*** Connect to %r database" % DBNAME)
try:
mongo = MongoTest()
except RuntimeError:
printf("\nERROR: MongoDB server unreachable, exit")
return
printf("\n*** Insert names into table")
mongo.insert()
mongo.dbDump()
printf("\n*** Move users to a random group")
fr, to, num = mongo.update()
printf("\t(%d users moved) from (%d) to (%d)" % (num, fr, to))
mongo.dbDump()
printf("\n*** Randomly delete group")
rm, num = mongo.delete()
printf("\t(group #%d; %d users removed)" % (rm, num))
mongo.dbDump()
printf("\n*** Drop users table")
mongo.db.drop_collection(COLLECTION)
printf("\n*** Close cxns")
mongo.finish()
if __name__ == "__main__":
main()