Why Gemfury? Push, build, and install  RubyGems npm packages Python packages Maven artifacts PHP packages Go Modules Debian packages RPM packages NuGet packages

Repository URL to install this package:

Details    
frozendict / test / debug.py
Size: Mime:
#!/usr/bin/env python3

import frozendict

assert frozendict.c_ext

from frozendict import frozendict, coold
from uuid import uuid4
import pickle
import sys
from pathlib import Path
from copy import copy, deepcopy
from collections.abc import MutableMapping

def getUuid():
    return str(uuid4())

class F(frozendict):
    def __new__(cls, *args, **kwargs):
            return super().__new__(cls, *args, **kwargs)

class FMissing(frozendict):
    def __new__(cls, *args, **kwargs):
            return super().__new__(cls, *args, **kwargs)
    
    def __missing__(self, key):
        return key

class C(coold):
    def __new__(cls, *args, **kwargs):
            return super().__new__(cls, *args, **kwargs)

class Map(MutableMapping):
    def __init__(self, *args, **kwargs):
        self._dict = dict(*args, **kwargs)
    
    def __getitem__(self, key):
        return self._dict[key]
    
    def __setitem__(self, key, value):
        self._dict[key] = value
    
    def __delitem__(self, key):
        del self._dict[key]
    
    def __iter__(self):
        return iter(self._dict)
    
    def __len__(self):
        return len(self._dict)

def print_info(klass, iterations, stmt):
    if "\n" in stmt:
        sep = "\n"
    else:
        sep = " "
    
    print(
        f"Class = {klass.__name__} - Loops: {iterations} - Evaluating:{sep}{stmt}", 
        flush=True
    )

def print_sep():
    print(
        "------------------------------------------------------------------------------", 
        flush=True
    )

argv = sys.argv
iterations = None
args_num = 1
right_len = args_num + 1
len_argv = len(argv)

if len_argv == right_len:
    try:
        iterations = int(argv[1])
    except Exception:
        pass

if len_argv != right_len or iterations == None:
    err = (
        f"{Path(__file__).name} should have {args_num} and only " + 
        f"{args_num} integer parameter"
    )
    
    print(err, file=sys.stderr)
    exit(1)

key_in = getUuid()
dict_1 = {key_in: 0}
dict_tmp = {getUuid(): i for i in range(1, 1000)}
dict_1.update(dict_tmp)
generator_1 = ((key, val) for key, val in dict_1.items())
key_notin = getUuid()
dict_2 = {getUuid(): i for i in range(1000)}
dict_3 = {i: i for i in range(1000)}
dict_hole = dict_1.copy()
del dict_hole[key_in]
dict_unashable = dict_1.copy()
dict_unashable.update({getUuid(): []})
dict_1_items = tuple(dict_1.items())
dict_1_keys = tuple(dict_1.keys())
dict_1_keys_set = set(dict_1_keys)

expressions = (
    'frozendict_class(dict_1)',
    'frozendict_class(dict_3)',
    'frozendict_class()',
    'frozendict_class({})',
    'frozendict_class([])',
    'frozendict_class({}, **{})',
    'frozendict_class(**dict_1)',
    'frozendict_class(dict_1, **dict_2)', 
    'frozendict_class(fd_1)', 
    'frozendict_class(generator_1)', 
    'frozendict_class(dict_hole)',
    'fd_1.copy()', 
    'fd_1 == dict_1', 
    'fd_1 == fd_1', 
    'fd_1 != dict_hole', 
    'fd_1 != dict_2', 
    'fd_1 == dict_hole', 
    'fd_1 == dict_2', 
    'pickle.loads(pickle.dumps(fd_1))',
    'frozendict_class(dict_1_items)',
    'tuple(fd_1.keys())',
    'tuple(fd_1.values())',
    'tuple(fd_1.items())',
    'frozendict_class.fromkeys(dict_1)',
    'frozendict_class.fromkeys(dict_1, 1)',
    'frozendict_class.fromkeys(dict_1_keys)',
    'frozendict_class.fromkeys(dict_1_keys, 1)',
    'frozendict_class.fromkeys(dict_1_keys_set)',
    'frozendict_class.fromkeys(dict_1_keys_set, 1)',
    'repr(fd_1)',
    'fd_1 | dict_2',
    'hash(fd_1)',
    'frozendict_class() == frozendict_class()', 
    'tuple(reversed(fd_1))', 
    'tuple(reversed(fd_1.keys()))', 
    'tuple(reversed(fd_1.items()))', 
    'tuple(reversed(fd_1.values()))', 
    'iter(fd_1).__length_hint__()', 
    'len(fd_1)', 
    'len(fd_1.keys())', 
    'len(fd_1.items())', 
    'len(fd_1.values())', 
    'fd_1.keys().mapping == fd_1', 
    'fd_1.items().mapping == fd_1', 
    'fd_1.values().mapping == fd_1', 
    'fd_1[key_in]', 
    'fd_1.get(key_in)', 
    'fd_1.get(key_notin)', 
    'fd_1.get(key_notin, 1)', 
    'key_in in fd_1', 
    'key_notin in fd_1', 
    'fd_1.copy()', 
    'copy(fd_1)', 
    'deepcopy(fd_1)', 
    'deepcopy(fd_unashable)', 
    'fd_1.keys() == dict_1.keys()', 
    'fd_1.items() == dict_1.items()', 
    'key_notin in fd_1.keys()', 
    '(key_notin, 0) in fd_1.items()', 
    'FMissing(fd_1)[0]', 
    'frozendict_class(Map(dict_1)) == dict_1', 
    'fd_1.keys().isdisjoint(dict_3)', 
    'fd_1.keys().isdisjoint(fd_1)', 
    'fd_1.items().isdisjoint(dict_3.items())', 
    'fd_1.items().isdisjoint(fd_1.items())', 
    'fd_unashable.keys() - fd_1.keys()', 
    'fd_1.items() - frozendict_class(dict_hole).items()', 
    'fd_1.keys() & frozendict_class(dict_hole).keys()', 
    'fd_1.items() & frozendict_class(dict_hole).items()', 
    'fd_1.keys() | frozendict_class(dict_2).keys()', 
    'fd_1.items() | frozendict_class(dict_2).items()', 
    'fd_1.keys() ^ frozendict_class(dict_hole).keys()', 
    'fd_1.items() ^ frozendict_class(dict_hole).items()', 
    'pickle.loads(pickle.dumps(iter(fd_1.keys())))', 
    'pickle.loads(pickle.dumps(iter(fd_1.items())))', 
    'pickle.loads(pickle.dumps(iter(fd_1.values())))', 
    'frozendict_class(dict_hole).keys() < fd_1.keys()', 
    'frozendict_class(dict_hole).keys() <= fd_1.keys()', 
    'frozendict_class(dict_hole).items() < fd_1.items()', 
    'fd_1.keys() > frozendict_class(dict_hole).keys()', 
    'fd_1.keys() >= frozendict_class(dict_hole).keys()', 
    'fd_1.items() > frozendict_class(dict_hole).items()', 
    'fd_1.items() >= frozendict_class(dict_hole).items()', 
)

codes = (
"""
for x in fd_1:
    pass
""",
"""
for x in iter(fd_1):
    pass
""",
"""
for x in fd_1.keys():
    pass
""",
"""
for x in fd_1.values():
    pass
""",
"""
for x in fd_1.items():
    pass
""",
"""
try:
    hash(fd_unashable)
except TypeError:
    pass
""",
"""
try:
    fd_1[key_notin]
except KeyError:
    pass
""",
)

print_sep()

for frozendict_class in (frozendict, F):
    print_info(
        frozendict_class, 
        iterations, 
        "frozendict_class(dict_1)"
    )
    
    fd_1 = frozendict_class(dict_1)
    print_sep()
    print_info(
        frozendict_class, 
        iterations, 
        "frozendict_class(dict_unashable)"
    )
    
    fd_unashable = frozendict_class(dict_unashable)
    print_sep()
    
    for expression in expressions:
        print_info(frozendict_class, iterations, expression)
        
        for j in range(iterations):
            eval(expression)
        
        print_sep()
    
    for code in codes:
        print_info(frozendict_class, iterations, code)
        
        for j in range(iterations):
            exec(code)
        
        print_sep()

coold_expressions = (
    "c1.set(key_in, 1000)", 
    "c1.set(key_notin, 1000)", 
    "c1.delete(key_in)", 
    "c1.setdefault(key_in)", 
    "c1.setdefault(key_notin)", 
    "c1.setdefault(key_notin, 1000)", 
)

for cooold_class in (coold, C):
    print_info(cooold_class, iterations, "cooold_class(dict_1)")
    c1 = cooold_class(dict_1)
    print_sep()
    
    for expression in coold_expressions:
        print_info(cooold_class, iterations, expression)
        
        for j in range(iterations):
            eval(expression)
        
        print_sep()