Source code for thoth.adviser.step

#!/usr/bin/env python3
# thoth-adviser
# Copyright(C) 2019 - 2021 Fridolin Pokorny
#
# This program is free software: you can redistribute it and / or modify
# it under the terms of the GNU General Public License as published by
# the Free Software Foundation, either version 3 of the License, or
# (at your option) any later version.
#
# This program is distributed in the hope that it will be useful,
# but WITHOUT ANY WARRANTY without even the implied warranty of
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
# GNU General Public License for more details.
#
# You should have received a copy of the GNU General Public License
# along with this program. If not, see <http://www.gnu.org/licenses/>.

"""A base class for implementing steps."""

import abc

import attr
from typing import Any
from typing import Dict
from typing import List
from typing import Optional
from typing import Tuple

from voluptuous import Schema
from voluptuous import Required
from voluptuous import Any as SchemaAny
from thoth.python import PackageVersion

from .state import State
from .unit import Unit


[docs]@attr.s(slots=True) class Step(Unit): """Step base class implementation. Configuration option `multi_package_resolution` states whether a step should be run if package is resolved multiple times for the same stack. """ CONFIGURATION_SCHEMA: Schema = Schema( {Required("package_name"): SchemaAny(str, None), Required("multi_package_resolution"): bool} ) CONFIGURATION_DEFAULT: Dict[str, Any] = {"package_name": None, "multi_package_resolution": False} SCORE_MAX = 1.0 SCORE_MIN = -1.0
[docs] @staticmethod def is_step_unit_type() -> bool: """Check if this unit is of type step.""" return True
[docs] @abc.abstractmethod def run( self, state: State, package_version: PackageVersion ) -> Optional[Tuple[Optional[float], Optional[List[Dict[str, str]]]]]: """Run main entry-point for steps to filter and score packages."""