function ElementValidationTest::testAjaxElementValidation

Same name and namespace in other branches
  1. 9 core/tests/Drupal/FunctionalJavascriptTests/Ajax/ElementValidationTest.php \Drupal\FunctionalJavascriptTests\Ajax\ElementValidationTest::testAjaxElementValidation()
  2. 8.9.x core/tests/Drupal/FunctionalJavascriptTests/Ajax/ElementValidationTest.php \Drupal\FunctionalJavascriptTests\Ajax\ElementValidationTest::testAjaxElementValidation()
  3. 11.x core/tests/Drupal/FunctionalJavascriptTests/Ajax/ElementValidationTest.php \Drupal\FunctionalJavascriptTests\Ajax\ElementValidationTest::testAjaxElementValidation()

Tries to post an Ajax change to a form that has a validated element.

Drupal AJAX commands update the DOM echoing back the validated values in the form of messages that appear on the page.

File

core/tests/Drupal/FunctionalJavascriptTests/Ajax/ElementValidationTest.php, line 32

Class

ElementValidationTest
Various tests of AJAX behavior.

Namespace

Drupal\FunctionalJavascriptTests\Ajax

Code

public function testAjaxElementValidation() : void {
  $this->drupalGet('ajax_validation_test');
  $page = $this->getSession()
    ->getPage();
  $assert = $this->assertSession();
  // Partially complete the form with a string.
  $page->fillField('driver_text', 'some dumb text');
  // Move focus away from this field to trigger AJAX.
  $page->findField('spare_required_field')
    ->focus();
  // When the AJAX command updates the DOM a <ul> unsorted list
  // "message__list" structure will appear on the page echoing back the
  // "some dumb text" message.
  $placeholder_text = $assert->waitForElement('css', "[aria-label='Status message'] > ul > li > em:contains('some dumb text')");
  $this->assertNotNull($placeholder_text, 'A callback successfully echoed back a string.');
  $this->drupalGet('ajax_validation_test');
  // Partially complete the form with a number.
  $page->fillField('driver_number', '12345');
  $page->findField('spare_required_field')
    ->focus();
  // The AJAX request/response will complete successfully when an
  // InsertCommand injects a message with a placeholder element into the DOM
  // with the submitted number.
  $placeholder_number = $assert->waitForElement('css', "[aria-label='Status message'] > ul > li > em:contains('12345')");
  $this->assertNotNull($placeholder_number, 'A callback successfully echoed back a number.');
}

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