You are here

protected function AssertContentTrait::assertOptionSelected in Drupal 10

Same name and namespace in other branches
  1. 8 core/tests/Drupal/KernelTests/AssertContentTrait.php \Drupal\KernelTests\AssertContentTrait::assertOptionSelected()
  2. 9 core/tests/Drupal/KernelTests/AssertContentTrait.php \Drupal\KernelTests\AssertContentTrait::assertOptionSelected()

Asserts that a select option in the current page is checked.

@todo $id is unusable. Replace with $name.

Parameters

string $id: ID of select field to assert.

string $option: Option to assert.

string $message: (optional) A message to display with the assertion. Do not translate messages: use \Drupal\Component\Render\FormattableMarkup to embed variables in the message text, not t(). If left blank, a default message will be displayed.

string $group: (optional) The group this message is in, which is displayed in a column in test output. Use 'Debug' to indicate this is debugging output. Do not translate this string. Defaults to 'Browser'; most tests do not override this default.

Return value

bool TRUE on pass.

File

core/tests/Drupal/KernelTests/AssertContentTrait.php, line 1309

Class

AssertContentTrait
Provides test methods to assert content.

Namespace

Drupal\KernelTests

Code

protected function assertOptionSelected($id, $option, $message = '', $group = 'Browser') {
  $message = $message ? $message : new FormattableMarkup('Option @option for field @id is selected.', [
    '@option' => $option,
    '@id' => $id,
  ]);
  $elements = $this
    ->xpath('//select[@id=:id]//option[@value=:option]', [
    ':id' => $id,
    ':option' => $option,
  ]);
  $this
    ->assertNotEmpty($elements, $message);
  $this
    ->assertNotEmpty($elements[0]['selected'], $message);
  return TRUE;
}