404

[ Avaa Bypassed ]




Upload:

Command:

elspacio@18.116.27.25: ~ $
#!/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)

Filemanager

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