forked from cclgroupltd/ccl_chromium_reader
-
Notifications
You must be signed in to change notification settings - Fork 0
/
benchmark.py
35 lines (29 loc) · 1.04 KB
/
benchmark.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
import sys
import pathlib
import ccl_chromium_indexeddb
import time
def main(args):
start = time.time()
ldb_path = pathlib.Path(args[0])
wrapper = ccl_chromium_indexeddb.WrappedIndexDB(ldb_path)
for db_info in wrapper.database_ids:
db = wrapper[db_info.dbid_no]
print("------Database------")
print(f"db_number={db.db_number}; name={db.name}; origin={db.origin}")
print()
print("\t---Object Stores---")
for obj_store_name in db.object_store_names:
obj_store = db[obj_store_name]
print(f"\tobject_store_id={obj_store.object_store_id}; name={obj_store.name}")
try:
one_record = next(obj_store.iterate_records())
except StopIteration:
one_record = None
print()
end = time.time()
print("Elapsed time: {} seconds.".format(int(end-start)))
if __name__ == '__main__':
if len(sys.argv) < 2:
print(f"USAGE: {pathlib.Path(sys.argv[0]).name} <ldb dir path>")
exit(1)
main(sys.argv[1:])