You are here

public function ArrayComparator::assertEquals in Zircon Profile 8

Same name and namespace in other branches
  1. 8.0 vendor/sebastian/comparator/src/ArrayComparator.php \SebastianBergmann\Comparator\ArrayComparator::assertEquals()

Asserts that two values are equal.

Parameters

mixed $expected The first value to compare:

mixed $actual The second value to compare:

float $delta The allowed numerical distance between two values to: consider them equal

bool $canonicalize If set to TRUE, arrays are sorted before: comparison

bool $ignoreCase If set to TRUE, upper- and lowercasing is: ignored when comparing string values

array $processed:

Throws

ComparisonFailure Thrown when the comparison fails. Contains information about the specific errors that lead to the failure.

Overrides Comparator::assertEquals

1 call to ArrayComparator::assertEquals()
ObjectComparator::assertEquals in vendor/sebastian/comparator/src/ObjectComparator.php
Asserts that two values are equal.
1 method overrides ArrayComparator::assertEquals()
ObjectComparator::assertEquals in vendor/sebastian/comparator/src/ObjectComparator.php
Asserts that two values are equal.

File

vendor/sebastian/comparator/src/ArrayComparator.php, line 46

Class

ArrayComparator
Compares arrays for equality.

Namespace

SebastianBergmann\Comparator

Code

public function assertEquals($expected, $actual, $delta = 0.0, $canonicalize = false, $ignoreCase = false, array &$processed = array()) {
  if ($canonicalize) {
    sort($expected);
    sort($actual);
  }
  $remaining = $actual;
  $expString = $actString = "Array (\n";
  $equal = true;
  foreach ($expected as $key => $value) {
    unset($remaining[$key]);
    if (!array_key_exists($key, $actual)) {
      $expString .= sprintf("    %s => %s\n", $this->exporter
        ->export($key), $this->exporter
        ->shortenedExport($value));
      $equal = false;
      continue;
    }
    try {
      $comparator = $this->factory
        ->getComparatorFor($value, $actual[$key]);
      $comparator
        ->assertEquals($value, $actual[$key], $delta, $canonicalize, $ignoreCase, $processed);
      $expString .= sprintf("    %s => %s\n", $this->exporter
        ->export($key), $this->exporter
        ->shortenedExport($value));
      $actString .= sprintf("    %s => %s\n", $this->exporter
        ->export($key), $this->exporter
        ->shortenedExport($actual[$key]));
    } catch (ComparisonFailure $e) {
      $expString .= sprintf("    %s => %s\n", $this->exporter
        ->export($key), $e
        ->getExpectedAsString() ? $this
        ->indent($e
        ->getExpectedAsString()) : $this->exporter
        ->shortenedExport($e
        ->getExpected()));
      $actString .= sprintf("    %s => %s\n", $this->exporter
        ->export($key), $e
        ->getActualAsString() ? $this
        ->indent($e
        ->getActualAsString()) : $this->exporter
        ->shortenedExport($e
        ->getActual()));
      $equal = false;
    }
  }
  foreach ($remaining as $key => $value) {
    $actString .= sprintf("    %s => %s\n", $this->exporter
      ->export($key), $this->exporter
      ->shortenedExport($value));
    $equal = false;
  }
  $expString .= ')';
  $actString .= ')';
  if (!$equal) {
    throw new ComparisonFailure($expected, $actual, $expString, $actString, false, 'Failed asserting that two arrays are equal.');
  }
}