1.20.x common.test CommonBackdropRenderTestCase::testBackdropRenderSorting()

Test sorting by weight.

File

modules/simpletest/tests/common.test, line 1938
Tests for common.inc functionality.

Class

CommonBackdropRenderTestCase
Tests for backdrop_render().

Code

function testBackdropRenderSorting() {
  $first = $this->randomName();
  $second = $this->randomName();
  // Build an array with '#weight' set for each element.
  $elements = array(
    'second' => array(
      '#weight' => 10,
      '#markup' => $second,
    ),
    'first' => array(
      '#weight' => 0,
      '#markup' => $first,
    ),
  );
  $output = backdrop_render($elements);

  // The lowest weight element should appear last in $output.
  $this->assertTrue(strpos($output, $second) > strpos($output, $first), 'Elements were sorted correctly by weight.');

  // Confirm that the $elements array has '#sorted' set to TRUE.
  $this->assertTrue($elements['#sorted'], "'#sorted' => TRUE was added to the array");

  // Pass $elements through element_children() and ensure it remains
  // sorted in the correct order. backdrop_render() will return an empty string
  // if used on the same array in the same request.
  $children = element_children($elements);
  $this->assertTrue(array_shift($children) == 'first', 'Child found in the correct order.');
  $this->assertTrue(array_shift($children) == 'second', 'Child found in the correct order.');


  // The same array structure again, but with #sorted set to TRUE.
  $elements = array(
    'second' => array(
      '#weight' => 10,
      '#markup' => $second,
    ),
    'first' => array(
      '#weight' => 0,
      '#markup' => $first,
    ),
    '#sorted' => TRUE,
  );
  $output = backdrop_render($elements);

  // The elements should appear in output in the same order as the array.
  $this->assertTrue(strpos($output, $second) < strpos($output, $first), 'Elements were not sorted.');
}