function NodeTitleXSSTest::testNodeTitleXSS in Zircon Profile 8
Same name and namespace in other branches
- 8.0 core/modules/node/src/Tests/NodeTitleXSSTest.php \Drupal\node\Tests\NodeTitleXSSTest::testNodeTitleXSS()
Tests XSS functionality with a node entity.
File
- core/modules/ node/ src/ Tests/ NodeTitleXSSTest.php, line 22 
- Contains \Drupal\node\Tests\NodeTitleXSSTest.
Class
- NodeTitleXSSTest
- Create a node with dangerous tags in its title and test that they are escaped.
Namespace
Drupal\node\TestsCode
function testNodeTitleXSS() {
  // Prepare a user to do the stuff.
  $web_user = $this
    ->drupalCreateUser(array(
    'create page content',
    'edit any page content',
  ));
  $this
    ->drupalLogin($web_user);
  $xss = '<script>alert("xss")</script>';
  $title = $xss . $this
    ->randomMachineName();
  $edit = array();
  $edit['title[0][value]'] = $title;
  $this
    ->drupalPostForm('node/add/page', $edit, t('Preview'));
  $this
    ->assertNoRaw($xss, 'Harmful tags are escaped when previewing a node.');
  $settings = array(
    'title' => $title,
  );
  $node = $this
    ->drupalCreateNode($settings);
  $this
    ->drupalGet('node/' . $node
    ->id());
  // Titles should be escaped.
  $this
    ->assertTitle(Html::escape($title) . ' | Drupal', 'Title is displayed when viewing a node.');
  $this
    ->assertNoRaw($xss, 'Harmful tags are escaped when viewing a node.');
  $this
    ->drupalGet('node/' . $node
    ->id() . '/edit');
  $this
    ->assertNoRaw($xss, 'Harmful tags are escaped when editing a node.');
}