function FilterAdminTest::testFilterAdmin

Tests filter administration functionality.

File

drupal/core/modules/filter/lib/Drupal/filter/Tests/FilterAdminTest.php, line 120
Definition of Drupal\filter\Tests\FilterAdminTest.

Class

FilterAdminTest
Tests the administrative functionality of the Filter module.

Namespace

Drupal\filter\Tests

Code

function testFilterAdmin() {
  $first_filter = 'filter_autop';
  $second_filter = 'filter_url';
  $basic = 'basic_html';
  $restricted = 'restricted_html';
  $full = 'full_html';
  $plain = 'plain_text';

  // Check that the fallback format exists and cannot be disabled.
  $this
    ->assertTrue($plain == filter_fallback_format(), 'The fallback format is set to plain text.');
  $this
    ->drupalGet('admin/config/content/formats');
  $this
    ->assertNoRaw('admin/config/content/formats/' . $plain . '/disable', 'Disable link for the fallback format not found.');
  $this
    ->drupalGet('admin/config/content/formats/' . $plain . '/disable');
  $this
    ->assertResponse(403, 'The fallback format cannot be disabled.');

  // Verify access permissions to Full HTML format.
  $this
    ->assertTrue(filter_access(filter_format_load($full), $this->admin_user), 'Admin user may use Full HTML.');
  $this
    ->assertFalse(filter_access(filter_format_load($full), $this->web_user), 'Web user may not use Full HTML.');

  // Add an additional tag.
  $edit = array();
  $edit['filters[filter_html][settings][allowed_html]'] = '<a> <em> <strong> <cite> <code> <ul> <ol> <li> <dl> <dt> <dd> <quote>';
  $this
    ->drupalPost('admin/config/content/formats/' . $restricted, $edit, t('Save configuration'));
  $this
    ->assertUrl('admin/config/content/formats');
  $this
    ->drupalGet('admin/config/content/formats/' . $restricted);
  $this
    ->assertFieldByName('filters[filter_html][settings][allowed_html]', $edit['filters[filter_html][settings][allowed_html]'], 'Allowed HTML tag added.');
  $this
    ->assertTrue(cache('filter')
    ->isEmpty(), 'Cache cleared.');
  $elements = $this
    ->xpath('//select[@name=:first]/following::select[@name=:second]', array(
    ':first' => 'filters[' . $first_filter . '][weight]',
    ':second' => 'filters[' . $second_filter . '][weight]',
  ));
  $this
    ->assertTrue(!empty($elements), 'Order confirmed in admin interface.');

  // Reorder filters.
  $edit = array();
  $edit['filters[' . $second_filter . '][weight]'] = 1;
  $edit['filters[' . $first_filter . '][weight]'] = 2;
  $this
    ->drupalPost(NULL, $edit, t('Save configuration'));
  $this
    ->assertUrl('admin/config/content/formats');
  $this
    ->drupalGet('admin/config/content/formats/' . $restricted);
  $this
    ->assertFieldByName('filters[' . $second_filter . '][weight]', 1, 'Order saved successfully.');
  $this
    ->assertFieldByName('filters[' . $first_filter . '][weight]', 2, 'Order saved successfully.');
  $elements = $this
    ->xpath('//select[@name=:first]/following::select[@name=:second]', array(
    ':first' => 'filters[' . $second_filter . '][weight]',
    ':second' => 'filters[' . $first_filter . '][weight]',
  ));
  $this
    ->assertTrue(!empty($elements), 'Reorder confirmed in admin interface.');
  $filter_format = entity_load('filter_format', $restricted);
  foreach ($filter_format
    ->filters() as $filter_name => $filter) {
    if ($filter_name == $second_filter || $filter_name == $first_filter) {
      $filters[] = $filter_name;
    }
  }

  // Ensure that the second filter is now before the first filter.
  $this
    ->assertEqual($filter_format
    ->filters($second_filter)->weight + 1, $filter_format
    ->filters($first_filter)->weight, 'Order confirmed in configuration.');

  // Add format.
  $edit = array();
  $edit['format'] = drupal_strtolower($this
    ->randomName());
  $edit['name'] = $this
    ->randomName();
  $edit['roles[' . DRUPAL_AUTHENTICATED_RID . ']'] = 1;
  $edit['filters[' . $second_filter . '][status]'] = TRUE;
  $edit['filters[' . $first_filter . '][status]'] = TRUE;
  $this
    ->drupalPost('admin/config/content/formats/add', $edit, t('Save configuration'));
  $this
    ->assertUrl('admin/config/content/formats');
  $this
    ->assertRaw(t('Added text format %format.', array(
    '%format' => $edit['name'],
  )), 'New filter created.');
  drupal_static_reset('filter_formats');
  $format = filter_format_load($edit['format']);
  $this
    ->assertNotNull($format, 'Format found in database.');
  $this
    ->drupalGet('admin/config/content/formats/' . $format->format);
  $this
    ->assertFieldByName('roles[' . DRUPAL_AUTHENTICATED_RID . ']', '', 'Role found.');
  $this
    ->assertFieldByName('filters[' . $second_filter . '][status]', '', 'Line break filter found.');
  $this
    ->assertFieldByName('filters[' . $first_filter . '][status]', '', 'Url filter found.');

  // Disable new filter.
  $this
    ->drupalPost('admin/config/content/formats/' . $format->format . '/disable', array(), t('Disable'));
  $this
    ->assertUrl('admin/config/content/formats');
  $this
    ->assertRaw(t('Disabled text format %format.', array(
    '%format' => $edit['name'],
  )), 'Format successfully disabled.');

  // Allow authenticated users on full HTML.
  $format = filter_format_load($full);
  $edit = array();
  $edit['roles[' . DRUPAL_ANONYMOUS_RID . ']'] = 0;
  $edit['roles[' . DRUPAL_AUTHENTICATED_RID . ']'] = 1;
  $this
    ->drupalPost('admin/config/content/formats/' . $full, $edit, t('Save configuration'));
  $this
    ->assertUrl('admin/config/content/formats');
  $this
    ->assertRaw(t('The text format %format has been updated.', array(
    '%format' => $format->name,
  )), 'Full HTML format successfully updated.');

  // Switch user.
  $this
    ->drupalLogin($this->web_user);
  $this
    ->drupalGet('node/add/page');
  $this
    ->assertRaw('<option value="' . $full . '">Full HTML</option>', 'Full HTML filter accessible.');

  // Use basic HTML and see if it removes tags that are not allowed.
  $body = '<em>' . $this
    ->randomName() . '</em>';
  $extra_text = 'text';
  $text = $body . '<random>' . $extra_text . '</random>';
  $edit = array();
  $langcode = Language::LANGCODE_NOT_SPECIFIED;
  $edit["title"] = $this
    ->randomName();
  $edit["body[{$langcode}][0][value]"] = $text;
  $edit["body[{$langcode}][0][format]"] = $basic;
  $this
    ->drupalPost('node/add/page', $edit, t('Save'));
  $this
    ->assertRaw(t('Basic page %title has been created.', array(
    '%title' => $edit["title"],
  )), 'Filtered node created.');
  $node = $this
    ->drupalGetNodeByTitle($edit["title"]);
  $this
    ->assertTrue($node, 'Node found in database.');
  $this
    ->drupalGet('node/' . $node->nid);
  $this
    ->assertRaw($body . $extra_text, 'Filter removed invalid tag.');

  // Use plain text and see if it escapes all tags, whether allowed or not.
  // In order to test plain text, we have to enable the hidden variable for
  // "show_fallback_format", which displays plain text in the format list.
  config('filter.settings')
    ->set('always_show_fallback_choice', TRUE)
    ->save();
  $edit = array();
  $edit["body[{$langcode}][0][format]"] = $plain;
  $this
    ->drupalPost('node/' . $node->nid . '/edit', $edit, t('Save'));
  $this
    ->drupalGet('node/' . $node->nid);
  $this
    ->assertText(check_plain($text), 'The "Plain text" text format escapes all HTML tags.');
  config('filter.settings')
    ->set('always_show_fallback_choice', FALSE)
    ->save();

  // Switch user.
  $this
    ->drupalLogin($this->admin_user);

  // Clean up.
  // Allowed tags.
  $edit = array();
  $edit['filters[filter_html][settings][allowed_html]'] = '<a> <em> <strong> <cite> <code> <ul> <ol> <li> <dl> <dt> <dd>';
  $this
    ->drupalPost('admin/config/content/formats/' . $basic, $edit, t('Save configuration'));
  $this
    ->assertUrl('admin/config/content/formats');
  $this
    ->drupalGet('admin/config/content/formats/' . $basic);
  $this
    ->assertFieldByName('filters[filter_html][settings][allowed_html]', $edit['filters[filter_html][settings][allowed_html]'], 'Changes reverted.');

  // Full HTML.
  $edit = array();
  $edit['roles[' . DRUPAL_AUTHENTICATED_RID . ']'] = FALSE;
  $this
    ->drupalPost('admin/config/content/formats/' . $full, $edit, t('Save configuration'));
  $this
    ->assertUrl('admin/config/content/formats');
  $this
    ->assertRaw(t('The text format %format has been updated.', array(
    '%format' => $format->name,
  )), 'Full HTML format successfully reverted.');
  $this
    ->drupalGet('admin/config/content/formats/' . $full);
  $this
    ->assertFieldByName('roles[' . DRUPAL_AUTHENTICATED_RID . ']', $edit['roles[' . DRUPAL_AUTHENTICATED_RID . ']'], 'Changes reverted.');

  // Filter order.
  $edit = array();
  $edit['filters[' . $second_filter . '][weight]'] = 2;
  $edit['filters[' . $first_filter . '][weight]'] = 1;
  $this
    ->drupalPost('admin/config/content/formats/' . $basic, $edit, t('Save configuration'));
  $this
    ->assertUrl('admin/config/content/formats');
  $this
    ->drupalGet('admin/config/content/formats/' . $basic);
  $this
    ->assertFieldByName('filters[' . $second_filter . '][weight]', $edit['filters[' . $second_filter . '][weight]'], 'Changes reverted.');
  $this
    ->assertFieldByName('filters[' . $first_filter . '][weight]', $edit['filters[' . $first_filter . '][weight]'], 'Changes reverted.');
}