#!/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)
Name | Type | Size | Permission | Actions |
---|---|---|---|---|
__pycache__ | Folder | 0755 |
|
|
__init__.py | File | 501 B | 0644 |
|
__main__.py | File | 899 B | 0644 |
|
test_abc.py | File | 3.75 KB | 0644 |
|
test_check.py | File | 1.36 KB | 0644 |
|
test_classdef.py | File | 6.99 KB | 0644 |
|
test_dataclasses.py | File | 890 B | 0644 |
|
test_detect.py | File | 3.99 KB | 0644 |
|
test_dictviews.py | File | 1.31 KB | 0644 |
|
test_diff.py | File | 2.6 KB | 0644 |
|
test_extendpickle.py | File | 1.28 KB | 0644 |
|
test_fglobals.py | File | 1.64 KB | 0644 |
|
test_file.py | File | 13.26 KB | 0644 |
|
test_functions.py | File | 4.17 KB | 0644 |
|
test_functors.py | File | 930 B | 0644 |
|
test_logger.py | File | 2.33 KB | 0644 |
|
test_mixins.py | File | 3.91 KB | 0644 |
|
test_module.py | File | 1.9 KB | 0644 |
|
test_moduledict.py | File | 1.15 KB | 0644 |
|
test_nested.py | File | 3.07 KB | 0644 |
|
test_objects.py | File | 1.79 KB | 0644 |
|
test_properties.py | File | 1.31 KB | 0644 |
|
test_pycapsule.py | File | 1.38 KB | 0644 |
|
test_recursive.py | File | 4.08 KB | 0644 |
|
test_registered.py | File | 1.54 KB | 0644 |
|
test_restricted.py | File | 783 B | 0644 |
|
test_selected.py | File | 3.14 KB | 0644 |
|
test_session.py | File | 9.92 KB | 0644 |
|
test_source.py | File | 5.89 KB | 0644 |
|
test_temp.py | File | 2.56 KB | 0644 |
|
test_weakref.py | File | 1.56 KB | 0644 |
|