-
-
Notifications
You must be signed in to change notification settings - Fork 23
/
test_pickleshare.py
54 lines (45 loc) · 1.48 KB
/
test_pickleshare.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
from __future__ import print_function
import os
from pickleshare import PickleShareDB
def test_pickleshare(tmpdir):
db = PickleShareDB(tmpdir)
db.clear()
print("Should be empty:",db.items())
assert len(db) == 0
db['hello'] = 15
assert db['hello'] == 15
db['aku ankka'] = [1,2,313]
assert db['aku ankka'] == [1,2,313]
db['paths/nest/ok/keyname'] = [1,(5,46)]
assert db['paths/nest/ok/keyname'] == [1,(5,46)]
db.hset('hash', 'aku', 12)
db.hset('hash', 'ankka', 313)
assert db.hget('hash', 'aku') == 12
assert db.hget('hash', 'ankka') == 313
print("all hashed",db.hdict('hash'))
print(db.keys())
print(db.keys('paths/nest/ok/k*'))
print(dict(db)) # snapsot of whole db
db.uncache() # frees memory, causes re-reads later
# shorthand for accessing deeply nested files
lnk = db.getlink('myobjects/test')
lnk.foo = 2
lnk.bar = lnk.foo + 5
assert lnk.bar == 7
def test_stress(tmpdir):
db = PickleShareDB(tmpdir)
import time,sys
for i in range(100):
for j in range(500):
if i % 15 == 0 and i < 70:
if str(j) in db:
del db[str(j)]
continue
if j%33 == 0:
time.sleep(0.02)
db[str(j)] = db.get(str(j), []) + [(i,j,"proc %d" % os.getpid())]
db.hset('hash',j, db.hget('hash',j,15) + 1 )
print(i, end=' ')
sys.stdout.flush()
if i % 10 == 0:
db.uncache()