public function SchedulerDefaultTimeTest::testDefaultTime in Scheduler 2.x
Same name and namespace in other branches
- 8 tests/src/Functional/SchedulerDefaultTimeTest.php \Drupal\Tests\scheduler\Functional\SchedulerDefaultTimeTest::testDefaultTime()
Test the default time functionality during content creation and edit.
This test covers the default scenario where the dates are optional and not required. A javascript test covers the cases where the dates are required.
@dataProvider dataStandardEntityTypes()
File
- tests/
src/ Functional/ SchedulerDefaultTimeTest.php, line 68
Class
- SchedulerDefaultTimeTest
- Tests the default time functionality.
Namespace
Drupal\Tests\scheduler\FunctionalCode
public function testDefaultTime($entityTypeId, $bundle) {
$this
->drupalLogin($this->schedulerUser);
$config = $this
->config('scheduler.settings');
$titleField = $entityTypeId == 'media' ? 'name' : 'title';
// We cannot easily test the full validation message as they contain the
// current time which can be one or two seconds in the past. The best we can
// do is check the fixed part of the message as it is when passed to t() in
// Datetime::validateDatetime. Tests only needs to work in English anyway.
$publish_validation_message = 'The Publish on date is invalid.';
$unpublish_validation_message = 'The Unpublish on date is invalid.';
// First test with the "date only" functionality disabled.
$config
->set('allow_date_only', FALSE)
->save();
// Test that entering a time is required.
$title = 'No time ' . $this
->randomMachineName(8);
$edit = [
"{$titleField}[0][value]" => $title,
'publish_on[0][value][date]' => $this->publishTime
->format('Y-m-d'),
'unpublish_on[0][value][date]' => $this->unpublishTime
->format('Y-m-d'),
];
// Create an entity and check that the expected error messages are shown.
$add_url = $this
->entityAddUrl($entityTypeId, $bundle);
$this
->drupalGet($add_url);
$this
->submitForm($edit, 'Save');
// By default it is required to enter a time when scheduling content for
// publishing and for unpublishing.
$this
->assertSession()
->pageTextNotMatches('/' . $title . ' is scheduled to be published .* and unpublished .*/');
$this
->assertSession()
->pageTextContains($publish_validation_message);
$this
->assertSession()
->pageTextContains($unpublish_validation_message);
// Allow the user to enter only a date with no time.
$config
->set('allow_date_only', TRUE)
->save();
// Create an entity and check that the validation messages are not shown.
$this
->drupalGet($add_url);
$this
->submitForm($edit, 'Save');
$this
->assertSession()
->pageTextNotContains($publish_validation_message);
$this
->assertSession()
->pageTextNotContains($unpublish_validation_message);
// Get the pattern of the 'long' default date format.
$date_format_storage = $this->container
->get('entity_type.manager')
->getStorage('date_format');
$long_pattern = $date_format_storage
->load('long')
->getPattern();
// Check that the scheduled information is shown after saving and that the
// time is correct.
$this
->assertSession()
->pageTextContains(sprintf('%s is scheduled to be published %s and unpublished %s', $title, $this->publishTime
->format($long_pattern), $this->unpublishTime
->format($long_pattern)));
if ($entity = $this
->getEntityByTitle($entityTypeId, $title)) {
// Check that the correct scheduled dates are stored in the entity.
$this
->assertEquals($this->publishTime
->getTimestamp(), (int) $entity->publish_on->value, 'The publish_on value is stored correctly.');
$this
->assertEquals($this->unpublishTime
->getTimestamp(), (int) $entity->unpublish_on->value, 'The unpublish_on value is stored correctly.');
// Check that the default time has been added to the form on edit.
$this
->drupalGet($entity
->toUrl('edit-form'));
$this
->assertSession()
->FieldValueEquals('publish_on[0][value][time]', $this->defaultTime);
$this
->assertSession()
->FieldValueEquals('unpublish_on[0][value][time]', $this->defaultTime);
}
else {
$this
->fail('The expected entity was not found.');
}
}