Ausgabe der neuen DB Einträge

This commit is contained in:
hubobel 2022-01-02 21:50:48 +01:00
parent bad48e1627
commit cfbbb9ee3d
2399 changed files with 843193 additions and 43 deletions

View file

@ -0,0 +1,13 @@
"""Matchers that perform numeric comparisons."""
from .iscloseto import close_to
from .ordering_comparison import (
greater_than,
greater_than_or_equal_to,
less_than,
less_than_or_equal_to,
)
__author__ = "Jon Reid"
__copyright__ = "Copyright 2011 hamcrest.org"
__license__ = "BSD, see License.txt"

View file

@ -0,0 +1,91 @@
from decimal import Decimal
from math import fabs
from typing import Any, Union, overload
from hamcrest.core.base_matcher import BaseMatcher
from hamcrest.core.description import Description
from hamcrest.core.matcher import Matcher
__author__ = "Jon Reid"
__copyright__ = "Copyright 2011 hamcrest.org"
__license__ = "BSD, see License.txt"
Number = Union[float, Decimal] # Argh, https://github.com/python/mypy/issues/3186
def isnumeric(value: Any) -> bool:
"""Confirm that 'value' can be treated numerically; duck-test accordingly
"""
if isinstance(value, (float, complex, int)):
return True
try:
_ = (fabs(value) + 0 - 0) * 1
return True
except ArithmeticError:
return True
except:
return False
class IsCloseTo(BaseMatcher[Number]):
def __init__(self, value: Number, delta: Number) -> None:
if not isnumeric(value):
raise TypeError("IsCloseTo value must be numeric")
if not isnumeric(delta):
raise TypeError("IsCloseTo delta must be numeric")
self.value = value
self.delta = delta
def _matches(self, item: Number) -> bool:
if not isnumeric(item):
return False
return self._diff(item) <= self.delta
def _diff(self, item: Number) -> float:
# TODO - Fails for mixed floats & Decimals
return fabs(item - self.value) # type: ignore
def describe_mismatch(self, item: Number, mismatch_description: Description) -> None:
if not isnumeric(item):
super(IsCloseTo, self).describe_mismatch(item, mismatch_description)
else:
actual_delta = self._diff(item)
mismatch_description.append_description_of(item).append_text(
" differed by "
).append_description_of(actual_delta)
def describe_to(self, description: Description) -> None:
description.append_text("a numeric value within ").append_description_of(
self.delta
).append_text(" of ").append_description_of(self.value)
@overload
def close_to(value: float, delta: float) -> Matcher[float]:
...
@overload
def close_to(value: Decimal, delta: Decimal) -> Matcher[Decimal]:
...
def close_to(value, delta):
"""Matches if object is a number close to a given value, within a given
delta.
:param value: The value to compare against as the expected value.
:param delta: The maximum delta between the values for which the numbers
are considered close.
This matcher compares the evaluated object against ``value`` to see if the
difference is within a positive ``delta``.
Example::
close_to(3.0, 0.25)
"""
return IsCloseTo(value, delta)

View file

@ -0,0 +1,66 @@
import operator
from typing import Any, Callable
from hamcrest.core.base_matcher import BaseMatcher
from hamcrest.core.description import Description
from hamcrest.core.matcher import Matcher
__author__ = "Jon Reid"
__copyright__ = "Copyright 2011 hamcrest.org"
__license__ = "BSD, see License.txt"
class OrderingComparison(BaseMatcher[Any]):
def __init__(
self,
value: Any,
comparison_function: Callable[[Any, Any], bool],
comparison_description: str,
) -> None:
self.value = value
self.comparison_function = comparison_function
self.comparison_description = comparison_description
def _matches(self, item: Any) -> bool:
return self.comparison_function(item, self.value)
def describe_to(self, description: Description) -> None:
description.append_text("a value ").append_text(self.comparison_description).append_text(
" "
).append_description_of(self.value)
def greater_than(value: Any) -> Matcher[Any]:
"""Matches if object is greater than a given value.
:param value: The value to compare against.
"""
return OrderingComparison(value, operator.gt, "greater than")
def greater_than_or_equal_to(value: Any) -> Matcher[Any]:
"""Matches if object is greater than or equal to a given value.
:param value: The value to compare against.
"""
return OrderingComparison(value, operator.ge, "greater than or equal to")
def less_than(value: Any) -> Matcher[Any]:
"""Matches if object is less than a given value.
:param value: The value to compare against.
"""
return OrderingComparison(value, operator.lt, "less than")
def less_than_or_equal_to(value: Any) -> Matcher[Any]:
"""Matches if object is less than or equal to a given value.
:param value: The value to compare against.
"""
return OrderingComparison(value, operator.le, "less than or equal to")