-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathexam_tester_m2_part2.py
100 lines (83 loc) · 3.46 KB
/
exam_tester_m2_part2.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
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
from lstore.db import Database
from lstore.query import Query
from random import choice, randint, sample, seed
db = Database()
db.open('./ECS165')
# Getting the existing Grades table
grades_table = db.get_table('Grades')
# create a query class for the grades table
query = Query(db, grades_table)
# dictionary for records to test the database: test directory
records = {}
number_of_records = 1000
number_of_aggregates = 100
number_of_updates = 1
seed(3562901)
for i in range(0, number_of_records):
key = 92106429 + i
records[key] = [key, randint(0, 20), randint(0, 20), randint(0, 20), randint(0, 20)]
# Simulate updates
updated_records = {}
keys = sorted(list(records.keys()))
for _ in range(number_of_updates):
for key in keys:
updated_records[key] = records[key].copy()
for j in range(2, grades_table.num_columns):
value = randint(0, 20)
updated_records[key][j] = value
keys = sorted(list(records.keys()))
# Check records that were presisted in part 1
for key in keys:
record = query.select_version(key, 0, [1, 1, 1, 1, 1], -1)[0]
error = False
for i, column in enumerate(record.columns):
if column != records[key][i]:
error = True
if error:
print('select error on', key, ':', record, ', correct:', records[key])
print("Select for version -1 finished")
# Check records that were presisted in part 1
for key in keys:
record = query.select_version(key, 0, [1, 1, 1, 1, 1], -2)[0]
error = False
for i, column in enumerate(record.columns):
if column != records[key][i]:
error = True
if error:
print('select error on', key, ':', record, ', correct:', records[key])
print("Select for version -2 finished")
for key in keys:
record = query.select_version(key, 0, [1, 1, 1, 1, 1], 0)[0]
error = False
for i, column in enumerate(record.columns):
if column != updated_records[key][i]:
error = True
if error:
print('select error on', key, ':', record, ', correct:', records[key])
print("Select for version 0 finished")
for i in range(0, number_of_aggregates):
r = sorted(sample(range(0, len(keys)), 2))
column_sum = sum(map(lambda x: records[x][0] if x in records else 0, keys[r[0]: r[1] + 1]))
result = query.sum_version(keys[r[0]], keys[r[1]], 0, -1)
if column_sum != result:
print('sum error on [', keys[r[0]], ',', keys[r[1]], ']: ', result, ', correct: ', column_sum)
print("Aggregate version -1 finished")
for i in range(0, number_of_aggregates):
r = sorted(sample(range(0, len(keys)), 2))
column_sum = sum(map(lambda x: records[x][0] if x in records else 0, keys[r[0]: r[1] + 1]))
result = query.sum_version(keys[r[0]], keys[r[1]], 0, -2)
if column_sum != result:
print('sum error on [', keys[r[0]], ',', keys[r[1]], ']: ', result, ', correct: ', column_sum)
print("Aggregate version -2 finished")
for i in range(0, number_of_aggregates):
r = sorted(sample(range(0, len(keys)), 2))
updated_column_sum = sum(map(lambda x: updated_records[x][0] if x in updated_records else 0, keys[r[0]: r[1] + 1]))
updated_result = query.sum_version(keys[r[0]], keys[r[1]], 0, 0)
if updated_column_sum != updated_result:
print('sum error on [', keys[r[0]], ',', keys[r[1]], ']: ', updated_result, ', correct: ', updated_column_sum)
print("Aggregate version 0 finished")
deleted_keys = sample(keys, 100)
for key in deleted_keys:
query.delete(key)
records.pop(key, None)
db.close()