View source
<?php
namespace Drupal\Tests\system\Functional\System;
use Drupal\Tests\BrowserTestBase;
use Drupal\Tests\Traits\Core\CronRunTrait;
class CronRunTest extends BrowserTestBase {
use CronRunTrait;
public static $modules = [
'common_test',
'common_test_cron_helper',
'automated_cron',
];
protected $defaultTheme = 'stark';
public function testCronRun() {
$this
->drupalGet('cron');
$this
->assertSession()
->statusCodeEquals(404);
$key = $this
->randomMachineName(16);
$this
->drupalGet('cron/' . $key);
$this
->assertSession()
->statusCodeEquals(403);
$key = \Drupal::state()
->get('system.cron_key');
$this
->drupalGet('cron/' . $key);
$this
->assertSession()
->statusCodeEquals(204);
}
public function testAutomatedCron() {
$admin_user = $this
->drupalCreateUser([
'administer site configuration',
]);
$this
->drupalLogin($admin_user);
$cron_last = time();
$cron_safe_interval = 100;
\Drupal::state()
->set('system.cron_last', $cron_last);
$this
->config('automated_cron.settings')
->set('interval', $cron_safe_interval)
->save();
$this
->drupalGet('');
$this
->assertTrue($cron_last == \Drupal::state()
->get('system.cron_last'), 'Cron does not run when the cron interval is not passed.');
$cron_last = time() - 200;
\Drupal::state()
->set('system.cron_last', $cron_last);
$this
->drupalGet('');
sleep(1);
$this
->assertTrue($cron_last < \Drupal::state()
->get('system.cron_last'), 'Cron runs when the cron interval is passed.');
$this
->drupalPostForm('admin/config/system/cron', [
'interval' => 0,
], t('Save configuration'));
$this
->assertText(t('The configuration options have been saved.'));
$this
->drupalLogout();
$cron_last = time() - 200;
\Drupal::state()
->set('system.cron_last', $cron_last);
$this
->drupalGet('');
$this
->assertTrue($cron_last == \Drupal::state()
->get('system.cron_last'), 'Cron does not run when the cron threshold is disabled.');
}
public function testCronExceptions() {
\Drupal::state()
->delete('common_test.cron');
$this
->cronRun();
$result = \Drupal::state()
->get('common_test.cron');
$this
->assertEqual($result, 'success', 'Cron correctly handles exceptions thrown during hook_cron() invocations.');
}
public function testCronUI() {
$admin_user = $this
->drupalCreateUser([
'administer site configuration',
]);
$this
->drupalLogin($admin_user);
$this
->drupalGet('admin/config/system/cron');
$this
->assertNoText('years');
$cron_last = time() - 200;
\Drupal::state()
->set('system.cron_last', $cron_last);
$this
->drupalPostForm(NULL, [], 'Save configuration');
$this
->assertText('The configuration options have been saved.');
$this
->assertUrl('admin/config/system/cron');
$this
->assertEqual($cron_last, \Drupal::state()
->get('system.cron_last'), 'Cron does not run when saving the configuration form.');
$this
->drupalPostForm(NULL, [], 'Run cron');
$this
->assertTrue($cron_last < \Drupal::state()
->get('system.cron_last'), 'Cron runs when triggered manually.');
}
public function testManualCron() {
$admin_user = $this
->drupalCreateUser([
'administer site configuration',
]);
$this
->drupalLogin($admin_user);
$this
->drupalGet('admin/reports/status/run-cron');
$this
->assertSession()
->statusCodeEquals(403);
$this
->drupalGet('admin/reports/status');
$this
->clickLink(t('Run cron'));
$this
->assertSession()
->statusCodeEquals(200);
$this
->assertText(t('Cron ran successfully.'));
}
}