class ObjectComparator in Zircon Profile 8
Same name and namespace in other branches
- 8.0 vendor/sebastian/comparator/src/ObjectComparator.php \SebastianBergmann\Comparator\ObjectComparator
Compares objects for equality.
Hierarchy
- class \SebastianBergmann\Comparator\Comparator
- class \SebastianBergmann\Comparator\ArrayComparator
- class \SebastianBergmann\Comparator\ObjectComparator
- class \SebastianBergmann\Comparator\ArrayComparator
Expanded class hierarchy of ObjectComparator
File
- vendor/
sebastian/ comparator/ src/ ObjectComparator.php, line 16
Namespace
SebastianBergmann\ComparatorView source
class ObjectComparator extends ArrayComparator {
/**
* 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 is_object($expected) && is_object($actual);
}
/**
* 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
* @param array $processed
* @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, array &$processed = array()) {
if (get_class($actual) !== get_class($expected)) {
throw new ComparisonFailure($expected, $actual, $this->exporter
->export($expected), $this->exporter
->export($actual), false, sprintf('%s is not instance of expected class "%s".', $this->exporter
->export($actual), get_class($expected)));
}
// don't compare twice to allow for cyclic dependencies
if (in_array(array(
$actual,
$expected,
), $processed, true) || in_array(array(
$expected,
$actual,
), $processed, true)) {
return;
}
$processed[] = array(
$actual,
$expected,
);
// don't compare objects if they are identical
// this helps to avoid the error "maximum function nesting level reached"
// CAUTION: this conditional clause is not tested
if ($actual !== $expected) {
try {
parent::assertEquals($this
->toArray($expected), $this
->toArray($actual), $delta, $canonicalize, $ignoreCase, $processed);
} catch (ComparisonFailure $e) {
throw new ComparisonFailure($expected, $actual, substr_replace($e
->getExpectedAsString(), get_class($expected) . ' Object', 0, 5), substr_replace($e
->getActualAsString(), get_class($actual) . ' Object', 0, 5), false, 'Failed asserting that two objects are equal.');
}
}
}
/**
* Converts an object to an array containing all of its private, protected
* and public properties.
*
* @param object $object
* @return array
*/
protected function toArray($object) {
return $this->exporter
->toArray($object);
}
}
Members
Name | Modifiers | Type | Description | Overrides |
---|---|---|---|---|
ArrayComparator:: |
protected | function | ||
Comparator:: |
protected | property | ||
Comparator:: |
protected | property | ||
Comparator:: |
public | function | ||
Comparator:: |
public | function | ||
ObjectComparator:: |
public | function |
Returns whether the comparator can compare two values. Overrides ArrayComparator:: |
4 |
ObjectComparator:: |
public | function |
Asserts that two values are equal. Overrides ArrayComparator:: |
2 |
ObjectComparator:: |
protected | function | Converts an object to an array containing all of its private, protected and public properties. | 2 |