1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81
|
<?php
/*
* This file is part of the Predis package.
*
* (c) 2009-2020 Daniele Alessandri
* (c) 2021-2025 Till Krüss
*
* For the full copyright and license information, please view the LICENSE
* file that was distributed with this source code.
*/
namespace PHPUnit;
use PHPUnit\Framework\Constraint\Constraint;
class AssertSameWithPrecisionConstraint extends Constraint
{
/**
* @var mixed
*/
private $expectedValue;
/**
* @var int
*/
private $precision;
public function __construct($expectedValue, int $precision)
{
$this->expectedValue = $expectedValue;
$this->precision = $precision;
}
/**
* {@inheritdoc}
*/
public function matches($other): bool
{
if (gettype($this->expectedValue) !== gettype($other)) {
return false;
}
if (is_array($other)) {
$other = array_map([$this, 'roundToPrecision'], $other);
$this->expectedValue = array_map([$this, 'roundToPrecision'], $this->expectedValue);
return !array_diff($this->expectedValue, $other);
}
$other = $this->roundToPrecision($other);
$this->expectedValue = $this->roundToPrecision($this->expectedValue);
return $other === $this->expectedValue;
}
/**
* {@inheritDoc}
*/
public function toString(): string
{
return 'given value matches another value with given precision';
}
/**
* {@inheritdoc}
*/
protected function failureDescription($other): string
{
return $this->toString();
}
/**
* @param mixed $numeric
* @return float
*/
private function roundToPrecision($numeric): float
{
return round((float) $numeric, $this->precision);
}
}
|