PATH:
opt
/
cloudlinux
/
venv
/
lib
/
python3.11
/
site-packages
/
dill
/
tests
#!/usr/bin/env python # Author: Leonardo Gama (@leogama) # Copyright (c) 2022-2023 The Uncertainty Quantification Foundation. # License: 3-clause BSD. The full license text is available at: # - https://github.com/uqfoundation/dill/blob/master/LICENSE import logging import re import tempfile import dill from dill import detect from dill.logger import stderr_handler, adapter as logger try: from StringIO import StringIO except ImportError: from io import StringIO test_obj = {'a': (1, 2), 'b': object(), 'f': lambda x: x**2, 'big': list(range(10))} def test_logging(should_trace): buffer = StringIO() handler = logging.StreamHandler(buffer) logger.addHandler(handler) try: dill.dumps(test_obj) if should_trace: regex = re.compile(r'(\S*┬ \w.*[^)]' # begin pickling object r'|│*└ # \w.* \[\d+ (\wi)?B])' # object written (with size) ) for line in buffer.getvalue().splitlines(): assert regex.fullmatch(line) return buffer.getvalue() else: assert buffer.getvalue() == "" finally: logger.removeHandler(handler) buffer.close() def test_trace_to_file(stream_trace): file = tempfile.NamedTemporaryFile(mode='r') with detect.trace(file.name, mode='w'): dill.dumps(test_obj) file_trace = file.read() file.close() # Apparently, objects can change location in memory... reghex = re.compile(r'0x[0-9A-Za-z]+') file_trace, stream_trace = reghex.sub('0x', file_trace), reghex.sub('0x', stream_trace) # PyPy prints dictionary contents with repr(dict)... regdict = re.compile(r'(dict\.__repr__ of ).*') file_trace, stream_trace = regdict.sub(r'\1{}>', file_trace), regdict.sub(r'\1{}>', stream_trace) assert file_trace == stream_trace if __name__ == '__main__': logger.removeHandler(stderr_handler) test_logging(should_trace=False) detect.trace(True) test_logging(should_trace=True) detect.trace(False) test_logging(should_trace=False) loglevel = logging.ERROR logger.setLevel(loglevel) with detect.trace(): stream_trace = test_logging(should_trace=True) test_logging(should_trace=False) assert logger.getEffectiveLevel() == loglevel test_trace_to_file(stream_trace)
[-] test_registered.py
[open]
[-] test_mixins.py
[open]
[-] test_properties.py
[open]
[+]
..
[-] test_moduledict.py
[open]
[+]
__pycache__
[-] test_recursive.py
[open]
[-] test_abc.py
[open]
[-] test_session.py
[open]
[-] test_source.py
[open]
[-] test_module.py
[open]
[-] test_detect.py
[open]
[-] test_selected.py
[open]
[-] __main__.py
[open]
[-] test_file.py
[open]
[-] test_objects.py
[open]
[-] test_weakref.py
[open]
[-] test_pycapsule.py
[open]
[-] test_classdef.py
[open]
[-] test_dictviews.py
[open]
[-] test_logger.py
[open]
[-] test_restricted.py
[open]
[-] __init__.py
[open]
[-] test_diff.py
[open]
[-] test_fglobals.py
[open]
[-] test_check.py
[open]
[-] test_nested.py
[open]
[-] test_extendpickle.py
[open]
[-] test_dataclasses.py
[open]
[-] test_functors.py
[open]
[-] test_temp.py
[open]
[-] test_functions.py
[open]