1
|
|
|
import os |
2
|
|
|
import unittest |
3
|
|
|
from msquaredc.persistence import count |
4
|
|
|
from msquaredc.persistence import obtain |
5
|
|
|
from msquaredc.persistence import persist |
6
|
|
|
from msquaredc.persistence import BackedUpDict |
7
|
|
|
|
8
|
|
|
|
9
|
|
|
class TestPersistence(unittest.TestCase): |
10
|
|
|
def test_all(self): |
11
|
|
|
samples = [ |
12
|
|
|
{"x":1,"y":2,"z":3}, |
13
|
|
|
{"x":4,"y":5,"z":""}, |
14
|
|
|
] |
15
|
|
|
try: |
16
|
|
|
persist("test.txt",samples[0],"w+") |
17
|
|
|
persist("test.txt",samples[1],"a+") |
18
|
|
|
self.assertIn("test.txt",os.listdir(os.getcwd())) |
19
|
|
|
res = obtain("test.txt") |
20
|
|
|
#assert count("test.txt") == 3 |
21
|
|
|
finally: |
22
|
|
|
if "test.txt" in os.listdir(os.getcwd()): |
23
|
|
|
os.remove("test.txt") |
24
|
|
|
|
25
|
|
|
self.assertEqual(len(res),len(samples)) |
26
|
|
|
for i in range(len(samples)): |
27
|
|
|
for j in samples[i].keys(): |
28
|
|
|
self.assertIn(j,res[i].keys()) |
29
|
|
|
self.assertEqual(str(samples[i][j]),res[i][j],j+str(samples)+str(res)) |
30
|
|
|
|
31
|
|
|
|
32
|
|
|
class TestBackedUpDict(unittest.TestCase): |
33
|
|
|
def test_add(self): |
34
|
|
|
p = BackedUpDict(":memory:") |
35
|
|
|
p["bla"] = "blupp" |
36
|
|
|
self.assertEqual(p["bla"],"blupp") |
37
|
|
|
p[1] = 2 |
38
|
|
|
self.assertEqual(p[1],2) |
39
|
|
|
p[1] = "mahalo" |
40
|
|
|
self.assertEqual(p[1],"mahalo") |
41
|
|
|
self.assertIn(1,p.keys()) |
42
|
|
|
self.assertIn("bla",p.keys()) |
43
|
|
|
self.assertEqual(len(p),2) |
44
|
|
|
p["1"] = "2" |
45
|
|
|
self.assertEqual(p[1],"mahalo") |
46
|
|
|
|