You are here

public function NodeAdminTest::testContentAdminPages in Drupal 8

Same name and namespace in other branches
  1. 9 core/modules/node/tests/src/Functional/NodeAdminTest.php \Drupal\Tests\node\Functional\NodeAdminTest::testContentAdminPages()

Tests content overview with different user permissions.

Taxonomy filters are tested separately.

See also

TaxonomyNodeFilterTestCase

File

core/modules/node/tests/src/Functional/NodeAdminTest.php, line 132

Class

NodeAdminTest
Tests node administration page functionality.

Namespace

Drupal\Tests\node\Functional

Code

public function testContentAdminPages() {
  $this
    ->drupalLogin($this->adminUser);

  // Use an explicit changed time to ensure the expected order in the content
  // admin listing. We want these to appear in the table in the same order as
  // they appear in the following code, and the 'content' View has a table
  // style configuration with a default sort on the 'changed' field DESC.
  $time = time();
  $nodes['published_page'] = $this
    ->drupalCreateNode([
    'type' => 'page',
    'changed' => $time--,
  ]);
  $nodes['published_article'] = $this
    ->drupalCreateNode([
    'type' => 'article',
    'changed' => $time--,
  ]);
  $nodes['unpublished_page_1'] = $this
    ->drupalCreateNode([
    'type' => 'page',
    'changed' => $time--,
    'uid' => $this->baseUser1
      ->id(),
    'status' => 0,
  ]);
  $nodes['unpublished_page_2'] = $this
    ->drupalCreateNode([
    'type' => 'page',
    'changed' => $time,
    'uid' => $this->baseUser2
      ->id(),
    'status' => 0,
  ]);

  // Verify view, edit, and delete links for any content.
  $this
    ->drupalGet('admin/content');
  $this
    ->assertSession()
    ->statusCodeEquals(200);
  $node_type_labels = $this
    ->xpath('//td[contains(@class, "views-field-type")]');
  $delta = 0;
  foreach ($nodes as $node) {
    $this
      ->assertLinkByHref('node/' . $node
      ->id());
    $this
      ->assertLinkByHref('node/' . $node
      ->id() . '/edit');
    $this
      ->assertLinkByHref('node/' . $node
      ->id() . '/delete');

    // Verify that we can see the content type label.
    $this
      ->assertEqual(trim($node_type_labels[$delta]
      ->getText()), $node->type->entity
      ->label());
    $delta++;
  }

  // Verify filtering by publishing status.
  $this
    ->drupalGet('admin/content', [
    'query' => [
      'status' => TRUE,
    ],
  ]);
  $this
    ->assertLinkByHref('node/' . $nodes['published_page']
    ->id() . '/edit');
  $this
    ->assertLinkByHref('node/' . $nodes['published_article']
    ->id() . '/edit');
  $this
    ->assertNoLinkByHref('node/' . $nodes['unpublished_page_1']
    ->id() . '/edit');

  // Verify filtering by status and content type.
  $this
    ->drupalGet('admin/content', [
    'query' => [
      'status' => TRUE,
      'type' => 'page',
    ],
  ]);
  $this
    ->assertLinkByHref('node/' . $nodes['published_page']
    ->id() . '/edit');
  $this
    ->assertNoLinkByHref('node/' . $nodes['published_article']
    ->id() . '/edit');

  // Verify no operation links are displayed for regular users.
  $this
    ->drupalLogout();
  $this
    ->drupalLogin($this->baseUser1);
  $this
    ->drupalGet('admin/content');
  $this
    ->assertSession()
    ->statusCodeEquals(200);
  $this
    ->assertLinkByHref('node/' . $nodes['published_page']
    ->id());
  $this
    ->assertLinkByHref('node/' . $nodes['published_article']
    ->id());
  $this
    ->assertNoLinkByHref('node/' . $nodes['published_page']
    ->id() . '/edit');
  $this
    ->assertNoLinkByHref('node/' . $nodes['published_page']
    ->id() . '/delete');
  $this
    ->assertNoLinkByHref('node/' . $nodes['published_article']
    ->id() . '/edit');
  $this
    ->assertNoLinkByHref('node/' . $nodes['published_article']
    ->id() . '/delete');

  // Verify no unpublished content is displayed without permission.
  $this
    ->assertNoLinkByHref('node/' . $nodes['unpublished_page_1']
    ->id());
  $this
    ->assertNoLinkByHref('node/' . $nodes['unpublished_page_1']
    ->id() . '/edit');
  $this
    ->assertNoLinkByHref('node/' . $nodes['unpublished_page_1']
    ->id() . '/delete');

  // Verify no tableselect.
  $this
    ->assertNoFieldByName('nodes[' . $nodes['published_page']
    ->id() . ']', '', 'No tableselect found.');

  // Verify unpublished content is displayed with permission.
  $this
    ->drupalLogout();
  $this
    ->drupalLogin($this->baseUser2);
  $this
    ->drupalGet('admin/content');
  $this
    ->assertSession()
    ->statusCodeEquals(200);
  $this
    ->assertLinkByHref('node/' . $nodes['unpublished_page_2']
    ->id());

  // Verify no operation links are displayed.
  $this
    ->assertNoLinkByHref('node/' . $nodes['unpublished_page_2']
    ->id() . '/edit');
  $this
    ->assertNoLinkByHref('node/' . $nodes['unpublished_page_2']
    ->id() . '/delete');

  // Verify user cannot see unpublished content of other users.
  $this
    ->assertNoLinkByHref('node/' . $nodes['unpublished_page_1']
    ->id());
  $this
    ->assertNoLinkByHref('node/' . $nodes['unpublished_page_1']
    ->id() . '/edit');
  $this
    ->assertNoLinkByHref('node/' . $nodes['unpublished_page_1']
    ->id() . '/delete');

  // Verify no tableselect.
  $this
    ->assertNoFieldByName('nodes[' . $nodes['unpublished_page_2']
    ->id() . ']', '', 'No tableselect found.');

  // Verify node access can be bypassed.
  $this
    ->drupalLogout();
  $this
    ->drupalLogin($this->baseUser3);
  $this
    ->drupalGet('admin/content');
  $this
    ->assertSession()
    ->statusCodeEquals(200);
  foreach ($nodes as $node) {
    $this
      ->assertLinkByHref('node/' . $node
      ->id());
    $this
      ->assertLinkByHref('node/' . $node
      ->id() . '/edit');
    $this
      ->assertLinkByHref('node/' . $node
      ->id() . '/delete');
  }
}