function TourTestBase::assertTourTips

Same name in this branch
  1. 8.9.x core/modules/tour/tests/src/Functional/TourTestBase.php \Drupal\Tests\tour\Functional\TourTestBase::assertTourTips()
Same name and namespace in other branches
  1. 10 core/modules/tour/tests/src/Functional/TourTestBase.php \Drupal\Tests\tour\Functional\TourTestBase::assertTourTips()
  2. 9 core/modules/tour/tests/src/Functional/TourTestBase.php \Drupal\Tests\tour\Functional\TourTestBase::assertTourTips()

Assert function to determine if tips rendered to the page have a corresponding page element.

// Basic example.
$this->assertTourTips();
// Advanced example. The following would be used for multipage or
// targeting a specific subset of tips.
$tips = array();
$tips[] = array(
  'data-id' => 'foo',
);
$tips[] = array(
  'data-id' => 'bar',
);
$tips[] = array(
  'data-class' => 'baz',
);
$this->assertTourTips($tips);

Parameters

array $tips: A list of tips which provide either a "data-id" or "data-class".

File

core/modules/tour/src/Tests/TourTestBase.php, line 38

Class

TourTestBase
Base class for testing Tour functionality.

Namespace

Drupal\tour\Tests

Code

public function assertTourTips($tips = []) {
  // Get the rendered tips and their data-id and data-class attributes.
  if (empty($tips)) {
    // Tips are rendered as <li> elements inside <ol id="tour">.
    $rendered_tips = $this->xpath('//ol[@id = "tour"]//li[starts-with(@class, "tip")]');
    foreach ($rendered_tips as $rendered_tip) {
      $attributes = (array) $rendered_tip->attributes();
      $tips[] = $attributes['@attributes'];
    }
  }
  // If the tips are still empty we need to fail.
  if (empty($tips)) {
    $this->fail('Could not find tour tips on the current page.');
  }
  else {
    // Check for corresponding page elements.
    $total = 0;
    $modals = 0;
    foreach ($tips as $tip) {
      if (!empty($tip['data-id'])) {
        $elements = $this->xpath('//*[@id="' . $tip['data-id'] . '"]');
        $this->assertTrue(!empty($elements) && count($elements) === 1, new FormattableMarkup('Found corresponding page element for tour tip with id #%data-id', [
          '%data-id' => $tip['data-id'],
        ]));
      }
      elseif (!empty($tip['data-class'])) {
        $elements = $this->xpath('//*[contain(@class, "' . $tip['data-id'] . '")]');
        $this->assertFalse(empty($elements), new FormattableMarkup('Found corresponding page element for tour tip with class .%data-class', [
          '%data-class' => $tip['data-class'],
        ]));
      }
      else {
        // It's a modal.
        $modals++;
      }
      $total++;
    }
    $this->pass(new FormattableMarkup('Total %total Tips tested of which %modals modal(s).', [
      '%total' => $total,
      '%modals' => $modals,
    ]));
  }
}

Buggy or inaccurate documentation? Please file an issue. Need support? Need help programming? Connect with the Drupal community.