404

[ Avaa Bypassed ]




Upload:

Command:

elspacio@18.222.67.8: ~ $
# Licensed under the LGPL: https://www.gnu.org/licenses/old-licenses/lgpl-2.1.en.html
# For details: https://github.com/PyCQA/astroid/blob/main/LICENSE
# Copyright (c) https://github.com/PyCQA/astroid/blob/main/CONTRIBUTORS.txt

"""Utility functions for test code that uses astroid ASTs as input."""

from __future__ import annotations

import contextlib
import functools
import sys
import warnings
from collections.abc import Callable

import pytest

from astroid import manager, nodes, transforms


def require_version(minver: str = "0.0.0", maxver: str = "4.0.0") -> Callable:
    """Compare version of python interpreter to the given one and skips the test if older."""

    def parse(python_version: str) -> tuple[int, ...]:
        try:
            return tuple(int(v) for v in python_version.split("."))
        except ValueError as e:
            msg = f"{python_version} is not a correct version : should be X.Y[.Z]."
            raise ValueError(msg) from e

    min_version = parse(minver)
    max_version = parse(maxver)

    def check_require_version(f):
        current: tuple[int, int, int] = sys.version_info[:3]
        if min_version < current <= max_version:
            return f

        version: str = ".".join(str(v) for v in sys.version_info)

        @functools.wraps(f)
        def new_f(*args, **kwargs):
            if current <= min_version:
                pytest.skip(f"Needs Python > {minver}. Current version is {version}.")
            elif current > max_version:
                pytest.skip(f"Needs Python <= {maxver}. Current version is {version}.")

        return new_f

    return check_require_version


def get_name_node(start_from, name, index=0):
    return [n for n in start_from.nodes_of_class(nodes.Name) if n.name == name][index]


@contextlib.contextmanager
def enable_warning(warning):
    warnings.simplefilter("always", warning)
    try:
        yield
    finally:
        # Reset it to default value, so it will take
        # into account the values from the -W flag.
        warnings.simplefilter("default", warning)


def brainless_manager():
    m = manager.AstroidManager()
    # avoid caching into the AstroidManager borg since we get problems
    # with other tests :
    m.__dict__ = {}
    m._failed_import_hooks = []
    m.astroid_cache = {}
    m._mod_file_cache = {}
    m._transform = transforms.TransformVisitor()
    m.extension_package_whitelist = set()
    return m

Filemanager

Name Type Size Permission Actions
__pycache__ Folder 0755
brain Folder 0755
interpreter Folder 0755
nodes Folder 0755
__init__.py File 4.98 KB 0644
__pkginfo__.py File 274 B 0644
_ast.py File 4.05 KB 0644
_backport_stdlib_names.py File 6.85 KB 0644
_cache.py File 786 B 0644
arguments.py File 12.65 KB 0644
astroid_manager.py File 572 B 0644
bases.py File 24.99 KB 0644
builder.py File 18.35 KB 0644
const.py File 1.07 KB 0644
constraint.py File 4.92 KB 0644
context.py File 5.85 KB 0644
decorators.py File 9.85 KB 0644
exceptions.py File 12.78 KB 0644
filter_statements.py File 9.42 KB 0644
helpers.py File 11.07 KB 0644
inference.py File 44.06 KB 0644
inference_tip.py File 2.82 KB 0644
manager.py File 17.54 KB 0644
mixins.py File 1.15 KB 0644
modutils.py File 22.96 KB 0644
node_classes.py File 1.8 KB 0644
objects.py File 12.46 KB 0644
protocols.py File 32.2 KB 0644
raw_building.py File 22.34 KB 0644
rebuilder.py File 77.86 KB 0644
scoped_nodes.py File 958 B 0644
test_utils.py File 2.38 KB 0644
transforms.py File 3.19 KB 0644
typing.py File 1.94 KB 0644
util.py File 4.62 KB 0644