function NodeAccessRebuildNodeGrantsTest::testNodeAccessRebuildNodeGrants

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

Tests rebuilding the node access permissions table with content.

File

core/modules/node/tests/src/Functional/NodeAccessRebuildNodeGrantsTest.php, line 55

Class

NodeAccessRebuildNodeGrantsTest
Tests node access rebuild functions with multiple node access modules.

Namespace

Drupal\Tests\node\Functional

Code

public function testNodeAccessRebuildNodeGrants() : void {
  \Drupal::service('module_installer')->install([
    'node_access_test',
  ]);
  \Drupal::state()->set('node_access_test.private', TRUE);
  node_access_test_add_field(NodeType::load('page'));
  $this->resetAll();
  // Create 30 nodes so that _node_access_rebuild_batch_operation() has to run
  // more than once.
  for ($i = 0; $i < 30; $i++) {
    $nodes[] = $this->drupalCreateNode([
      'uid' => $this->webUser
        ->id(),
      'private' => [
        [
          'value' => 1,
        ],
      ],
    ]);
  }
  /** @var \Drupal\node\NodeGrantDatabaseStorageInterface $grant_storage */
  $grant_storage = \Drupal::service('node.grant_storage');
  // Default realm access and node records are present.
  foreach ($nodes as $node) {
    $this->assertNotEmpty($node->private->value);
    $this->assertTrue($grant_storage->access($node, 'view', $this->webUser)
      ->isAllowed(), 'Prior to rebuilding node access the grant storage returns allowed for the node author.');
    $this->assertTrue($grant_storage->access($node, 'view', $this->adminUser)
      ->isAllowed(), 'Prior to rebuilding node access the grant storage returns allowed for the admin user.');
  }
  $this->assertEquals(1, \Drupal::service('node.grant_storage')->checkAll($this->webUser), 'There is an all realm access record');
  $this->assertTrue(\Drupal::state()->get('node.node_access_needs_rebuild'), 'Node access permissions need to be rebuilt');
  // Rebuild permissions.
  $this->drupalGet('admin/reports/status');
  $this->clickLink('Rebuild permissions');
  $this->submitForm([], 'Rebuild permissions');
  $this->assertSession()
    ->pageTextContains('The content access permissions have been rebuilt.');
  // Test if the rebuild by user that cannot bypass node access and does not
  // have access to the nodes has been successful.
  $this->assertFalse($this->adminUser
    ->hasPermission('bypass node access'));
  $this->assertNull(\Drupal::state()->get('node.node_access_needs_rebuild'), 'Node access permissions have been rebuilt');
  foreach ($nodes as $node) {
    $this->assertTrue($grant_storage->access($node, 'view', $this->webUser)
      ->isAllowed(), 'After rebuilding node access the grant storage returns allowed for the node author.');
    $this->assertFalse($grant_storage->access($node, 'view', $this->adminUser)
      ->isForbidden(), 'After rebuilding node access the grant storage returns forbidden for the admin user.');
  }
  $this->assertEmpty(\Drupal::service('node.grant_storage')->checkAll($this->webUser), 'There is no all realm access record');
  // Test an anonymous node access rebuild from code.
  $this->drupalLogout();
  node_access_rebuild();
  foreach ($nodes as $node) {
    $this->assertTrue($grant_storage->access($node, 'view', $this->webUser)
      ->isAllowed(), 'After rebuilding node access the grant storage returns allowed for the node author.');
    $this->assertFalse($grant_storage->access($node, 'view', $this->adminUser)
      ->isForbidden(), 'After rebuilding node access the grant storage returns forbidden for the admin user.');
  }
  $this->assertEmpty(\Drupal::service('node.grant_storage')->checkAll($this->webUser), 'There is no all realm access record');
}

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