function StatusExtraTest::testStatusExtra

Same name and namespace in other branches
  1. 10 core/modules/node/tests/src/Functional/Views/StatusExtraTest.php \Drupal\Tests\node\Functional\Views\StatusExtraTest::testStatusExtra()
  2. 9 core/modules/node/tests/src/Functional/Views/StatusExtraTest.php \Drupal\Tests\node\Functional\Views\StatusExtraTest::testStatusExtra()
  3. 8.9.x core/modules/node/tests/src/Functional/Views/StatusExtraTest.php \Drupal\Tests\node\Functional\Views\StatusExtraTest::testStatusExtra()

Tests the status extra filter.

File

core/modules/node/tests/src/Functional/Views/StatusExtraTest.php, line 44

Class

StatusExtraTest
Tests the node.status_extra field handler.

Namespace

Drupal\Tests\node\Functional\Views

Code

public function testStatusExtra() : void {
  $node_author = $this->drupalCreateUser([
    'view own unpublished content',
  ]);
  $node_author_not_unpublished = $this->drupalCreateUser();
  $normal_user = $this->drupalCreateUser();
  $privileged_user = $this->drupalCreateUser([
    'view any unpublished content',
  ]);
  $admin_user = $this->drupalCreateUser([
    'bypass node access',
  ]);
  // Create one published and one unpublished node by the admin.
  $node_published = $this->drupalCreateNode([
    'uid' => $admin_user->id(),
  ]);
  $node_unpublished = $this->drupalCreateNode([
    'uid' => $admin_user->id(),
    'status' => NodeInterface::NOT_PUBLISHED,
  ]);
  // Create one unpublished node by a certain author user.
  $node_unpublished2 = $this->drupalCreateNode([
    'uid' => $node_author->id(),
    'status' => NodeInterface::NOT_PUBLISHED,
  ]);
  // Create one unpublished node by a user who does not have the `view own
  // unpublished content` permission.
  $node_unpublished3 = $this->drupalCreateNode([
    'uid' => $node_author_not_unpublished->id(),
    'status' => NodeInterface::NOT_PUBLISHED,
  ]);
  // The administrator should simply see all nodes.
  $this->drupalLogin($admin_user);
  $this->drupalGet('test_status_extra');
  $this->assertSession()
    ->pageTextContains($node_published->label());
  $this->assertSession()
    ->pageTextContains($node_unpublished->label());
  $this->assertSession()
    ->pageTextContains($node_unpublished2->label());
  $this->assertSession()
    ->pageTextContains($node_unpublished3->label());
  // The privileged user should simply see all nodes.
  $this->drupalLogin($privileged_user);
  $this->drupalGet('test_status_extra');
  $this->assertSession()
    ->pageTextContains($node_published->label());
  $this->assertSession()
    ->pageTextContains($node_unpublished->label());
  $this->assertSession()
    ->pageTextContains($node_unpublished2->label());
  $this->assertSession()
    ->pageTextContains($node_unpublished3->label());
  // The node author should see the published node and their own node.
  $this->drupalLogin($node_author);
  $this->drupalGet('test_status_extra');
  $this->assertSession()
    ->pageTextContains($node_published->label());
  $this->assertSession()
    ->pageTextNotContains($node_unpublished->label());
  $this->assertSession()
    ->pageTextContains($node_unpublished2->label());
  $this->assertSession()
    ->pageTextNotContains($node_unpublished3->label());
  // The normal user should just see the published node.
  $this->drupalLogin($normal_user);
  $this->drupalGet('test_status_extra');
  $this->assertSession()
    ->pageTextContains($node_published->label());
  $this->assertSession()
    ->pageTextNotContains($node_unpublished->label());
  $this->assertSession()
    ->pageTextNotContains($node_unpublished2->label());
  $this->assertSession()
    ->pageTextNotContains($node_unpublished3->label());
  // The author without the permission to see their own unpublished node
  // should just see the published node.
  $this->drupalLogin($node_author_not_unpublished);
  $this->drupalGet('test_status_extra');
  $this->assertSession()
    ->pageTextContains($node_published->label());
  $this->assertSession()
    ->pageTextNotContains($node_unpublished->label());
  $this->assertSession()
    ->pageTextNotContains($node_unpublished2->label());
  $this->assertSession()
    ->pageTextNotContains($node_unpublished3->label());
  \Drupal::service('module_installer')->install([
    'node_access_test',
  ]);
  NodeType::create([
    'type' => 'page',
    'name' => 'page',
  ])->save();
  $this->addPrivateField(NodeType::load('page'));
  node_access_rebuild();
  $node_published_private = $this->drupalCreateNode([
    'uid' => $admin_user->id(),
    'private' => [
      'value' => 1,
    ],
  ]);
  $node_unpublished_private = $this->drupalCreateNode([
    'uid' => $admin_user->id(),
    'status' => NodeInterface::NOT_PUBLISHED,
    'private' => [
      'value' => 1,
    ],
  ]);
  // An unprivileged user must not see the published and unpublished content
  // when access is granted via hook_node_grants().
  $this->drupalLogin($this->drupalCreateUser());
  $this->drupalGet('test_status_extra');
  $this->assertSession()
    ->statusCodeEquals(200);
  $this->assertSession()
    ->pageTextNotContains($node_published_private->label());
  $this->assertSession()
    ->pageTextNotContains($node_unpublished_private->label());
  // A privileged user must see the published and unpublished content
  // when access is granted via hook_node_grants().
  $this->drupalLogin($this->drupalCreateUser(values: [
    'roles' => $this->drupalCreateRole([
      'node test view',
    ]),
  ]));
  $this->drupalGet('test_status_extra');
  $this->assertSession()
    ->pageTextContains($node_published_private->label());
  $this->assertSession()
    ->pageTextContains($node_unpublished_private->label());
}

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