public function SchedulerNodeAccessTest::testNodeAccess in Scheduler 8
Tests Scheduler cron functionality when access to the nodes is denied.
File
- tests/
src/ Functional/ SchedulerNodeAccessTest.php, line 25
Class
- SchedulerNodeAccessTest
- Tests that Scheduler cron has full access to the scheduled nodes.
Namespace
Drupal\Tests\scheduler\FunctionalCode
public function testNodeAccess() {
// scheduler_access_test_install() sets node_access_needs_rebuild(TRUE) and
// this works when testing the module interactively, but during simpletest
// the node access table is not rebuilt. Hence do that here explicitly here.
node_access_rebuild();
// Create data to test publishing then unpublishing via loop.
// @todo Convert this test to use a @dataProvider function instead of this
// array and the loop.
$test_data = [
'publish_on' => [
'status' => FALSE,
'before' => 'unpublished',
'after' => 'published',
],
'unpublish_on' => [
'status' => TRUE,
'before' => 'published',
'after' => 'unpublished',
],
];
foreach ($test_data as $field => $data) {
// Create a node with the necessary scheduler date.
$settings = [
'type' => $this->type,
'status' => $data['status'],
'title' => 'Test node to be ' . $data['after'],
$field => $this->requestTime + 1,
];
$node = $this
->drupalCreateNode($settings);
$this
->drupalGet('node/' . $node
->id());
// Before running cron, viewing the node should give "403 Not Authorized".
$this
->assertSession()
->statusCodeEquals(403);
// Delay so that the date entered is now in the past, then run cron.
sleep(2);
$this
->cronRun();
// Reload the node.
$this->nodeStorage
->resetCache([
$node
->id(),
]);
$node = $this->nodeStorage
->load($node
->id());
// Check that the node has been published or unpublished as required.
$this
->assertTrue($node
->isPublished() === !$data['status'], 'Scheduler has ' . $data['after'] . ' the node via cron.');
// Check the node is still not viewable.
$this
->drupalGet('node/' . $node
->id());
// After cron, viewing the node should still give "403 Not Authorized".
$this
->assertSession()
->statusCodeEquals(403);
}
// Log in and assert that the two dblog messages are shown.
$this
->drupalLogin($this->adminUser);
$this
->drupalGet('admin/reports/dblog');
$this
->assertSession()
->pageTextContains('scheduled publishing');
$this
->assertSession()
->pageTextContains('scheduled unpublishing');
}