class DateTimeComparator in Zircon Profile 8
Same name and namespace in other branches
- 8.0 vendor/sebastian/comparator/src/DateTimeComparator.php \SebastianBergmann\Comparator\DateTimeComparator
Compares DateTimeInterface instances for equality.
Hierarchy
- class \SebastianBergmann\Comparator\Comparator
- class \SebastianBergmann\Comparator\ArrayComparator
- class \SebastianBergmann\Comparator\ObjectComparator
- class \SebastianBergmann\Comparator\DateTimeComparator
- class \SebastianBergmann\Comparator\ObjectComparator
- class \SebastianBergmann\Comparator\ArrayComparator
Expanded class hierarchy of DateTimeComparator
File
- vendor/
sebastian/ comparator/ src/ DateTimeComparator.php, line 16
Namespace
SebastianBergmann\ComparatorView source
class DateTimeComparator extends ObjectComparator {
/**
* Returns whether the comparator can compare two values.
*
* @param mixed $expected The first value to compare
* @param mixed $actual The second value to compare
* @return bool
*/
public function accepts($expected, $actual) {
return ($expected instanceof \DateTime || $expected instanceof \DateTimeInterface) && ($actual instanceof \DateTime || $actual instanceof \DateTimeInterface);
}
/**
* Asserts that two values are equal.
*
* @param mixed $expected The first value to compare
* @param mixed $actual The second value to compare
* @param float $delta The allowed numerical distance between two values to
* consider them equal
* @param bool $canonicalize If set to TRUE, arrays are sorted before
* comparison
* @param bool $ignoreCase If set to TRUE, upper- and lowercasing is
* ignored when comparing string values
* @throws ComparisonFailure Thrown when the comparison
* fails. Contains information about the
* specific errors that lead to the failure.
*/
public function assertEquals($expected, $actual, $delta = 0.0, $canonicalize = false, $ignoreCase = false) {
$delta = new \DateInterval(sprintf('PT%sS', abs($delta)));
$expectedLower = clone $expected;
$expectedUpper = clone $expected;
if ($actual < $expectedLower
->sub($delta) || $actual > $expectedUpper
->add($delta)) {
throw new ComparisonFailure($expected, $actual, $this
->dateTimeToString($expected), $this
->dateTimeToString($actual), false, 'Failed asserting that two DateTime objects are equal.');
}
}
/**
* Returns an ISO 8601 formatted string representation of a datetime or
* 'Invalid DateTimeInterface object' if the provided DateTimeInterface was not properly
* initialized.
*
* @param \DateTimeInterface $datetime
* @return string
*/
protected function dateTimeToString($datetime) {
$string = $datetime
->format(\DateTime::ISO8601);
return $string ? $string : 'Invalid DateTimeInterface object';
}
}
Members
Name | Modifiers | Type | Description | Overrides |
---|---|---|---|---|
ArrayComparator:: |
protected | function | ||
Comparator:: |
protected | property | ||
Comparator:: |
protected | property | ||
Comparator:: |
public | function | ||
Comparator:: |
public | function | ||
DateTimeComparator:: |
public | function |
Returns whether the comparator can compare two values. Overrides ObjectComparator:: |
|
DateTimeComparator:: |
public | function |
Asserts that two values are equal. Overrides ObjectComparator:: |
|
DateTimeComparator:: |
protected | function | Returns an ISO 8601 formatted string representation of a datetime or 'Invalid DateTimeInterface object' if the provided DateTimeInterface was not properly initialized. | |
ObjectComparator:: |
protected | function | Converts an object to an array containing all of its private, protected and public properties. | 2 |