Update to Drupal 8.0.0 beta 14. For more information, see https://drupal.org/node/2544542
This commit is contained in:
		
							parent
							
								
									3b2511d96d
								
							
						
					
					
						commit
						81ccda77eb
					
				
					 2155 changed files with 54307 additions and 46870 deletions
				
			
		|  | @ -438,6 +438,46 @@ class DateTimeFieldTest extends WebTestBase { | |||
|     $this->assertOptionSelected("edit-$field_name-0-value-hour", '5', 'Correct hour selected.'); | ||||
|     $this->assertOptionSelected("edit-$field_name-0-value-minute", '15', 'Correct minute selected.'); | ||||
|     $this->assertOptionSelected("edit-$field_name-0-value-ampm", 'am', 'Correct ampm selected.'); | ||||
| 
 | ||||
|     // Test the widget using increment other than 1 and 24 hour mode.
 | ||||
|     entity_get_form_display($this->field->getTargetEntityTypeId(), $this->field->getTargetBundle(), 'default') | ||||
|       ->setComponent($field_name, array( | ||||
|         'type' => 'datetime_datelist', | ||||
|         'settings' => array( | ||||
|           'increment' => 15, | ||||
|           'date_order' => 'YMD', | ||||
|           'time_type' => '24', | ||||
|         ), | ||||
|       )) | ||||
|       ->save(); | ||||
|     \Drupal::entityManager()->clearCachedFieldDefinitions(); | ||||
| 
 | ||||
|     // Display creation form.
 | ||||
|     $this->drupalGet('entity_test/add'); | ||||
| 
 | ||||
|     // Other elements are unaffected by the changed settings.
 | ||||
|     $this->assertFieldByXPath("//*[@id=\"edit-$field_name-0-value-hour\"]", NULL, 'Hour element found.'); | ||||
|     $this->assertOptionSelected("edit-$field_name-0-value-hour", '', 'No hour selected.'); | ||||
|     $this->assertNoFieldByXPath("//*[@id=\"edit-$field_name-0-value-ampm\"]", NULL, 'AMPM element not found.'); | ||||
| 
 | ||||
|     // Submit a valid date and ensure it is accepted.
 | ||||
|     $date_value = array('year' => 2012, 'month' => 12, 'day' => 31, 'hour' => 17, 'minute' => 15); | ||||
| 
 | ||||
|     $edit = array(); | ||||
|     foreach ($date_value as $part => $value) { | ||||
|       $edit["{$field_name}[0][value][$part]"] = $value; | ||||
|     } | ||||
| 
 | ||||
|     $this->drupalPostForm(NULL, $edit, t('Save')); | ||||
|     preg_match('|entity_test/manage/(\d+)|', $this->url, $match); | ||||
|     $id = $match[1]; | ||||
|     $this->assertText(t('entity_test @id has been created.', array('@id' => $id))); | ||||
| 
 | ||||
|     $this->assertOptionSelected("edit-$field_name-0-value-year", '2012', 'Correct year selected.'); | ||||
|     $this->assertOptionSelected("edit-$field_name-0-value-month", '12', 'Correct month selected.'); | ||||
|     $this->assertOptionSelected("edit-$field_name-0-value-day", '31', 'Correct day selected.'); | ||||
|     $this->assertOptionSelected("edit-$field_name-0-value-hour", '17', 'Correct hour selected.'); | ||||
|     $this->assertOptionSelected("edit-$field_name-0-value-minute", '15', 'Correct minute selected.'); | ||||
|   } | ||||
| 
 | ||||
|   /** | ||||
|  |  | |||
							
								
								
									
										141
									
								
								core/modules/datetime/src/Tests/Views/ArgumentDateTimeTest.php
									
										
									
									
									
										Normal file
									
								
							
							
						
						
									
										141
									
								
								core/modules/datetime/src/Tests/Views/ArgumentDateTimeTest.php
									
										
									
									
									
										Normal file
									
								
							|  | @ -0,0 +1,141 @@ | |||
| <?php | ||||
| 
 | ||||
| /** | ||||
|  * @file | ||||
|  * Contains \Drupal\datetime\Tests\Views\ArgumentDateTimeTest. | ||||
|  */ | ||||
| 
 | ||||
| namespace Drupal\datetime\Tests\Views; | ||||
| 
 | ||||
| use Drupal\views\Views; | ||||
| 
 | ||||
| /** | ||||
|  * Tests the Drupal\datetime\Plugin\views\filter\Date handler. | ||||
|  * | ||||
|  * @group datetime | ||||
|  */ | ||||
| class ArgumentDateTimeTest extends DateTimeHandlerTestBase { | ||||
| 
 | ||||
|   /** | ||||
|    * {@inheritdoc} | ||||
|    */ | ||||
|   public static $testViews = ['test_argument_datetime']; | ||||
| 
 | ||||
|   /** | ||||
|    * {@inheritdoc} | ||||
|    */ | ||||
|   public function setUp() { | ||||
|     parent::setUp(); | ||||
| 
 | ||||
|     // Add some basic test nodes.
 | ||||
|     $dates = [ | ||||
|       '2000-10-10', | ||||
|       '2001-10-10', | ||||
|       '2002-01-01', | ||||
|     ]; | ||||
|     foreach ($dates as $date) { | ||||
|       $this->nodes[] = $this->drupalCreateNode([ | ||||
|         'field_date' => [ | ||||
|           'value' => $date, | ||||
|         ] | ||||
|       ]); | ||||
|     } | ||||
|   } | ||||
| 
 | ||||
|   /** | ||||
|    * Test year argument. | ||||
|    * | ||||
|    * @see \Drupal\datetime\Plugin\views\argument\YearDate | ||||
|    */ | ||||
|   public function testDatetimeArgumentYear() { | ||||
|     $view = Views::getView('test_argument_datetime'); | ||||
| 
 | ||||
|     // The 'default' display has the 'year' argument.
 | ||||
|     $view->setDisplay('default'); | ||||
|     $this->executeView($view, ['2000']); | ||||
|     $expected = []; | ||||
|     $expected[] = ['nid' => $this->nodes[0]->id()]; | ||||
|     $this->assertIdenticalResultset($view, $expected, $this->map); | ||||
|     $view->destroy(); | ||||
| 
 | ||||
|     $view->setDisplay('default'); | ||||
|     $this->executeView($view, ['2002']); | ||||
|     $expected = []; | ||||
|     $expected[] = ['nid' => $this->nodes[2]->id()]; | ||||
|     $this->assertIdenticalResultset($view, $expected, $this->map); | ||||
|     $view->destroy(); | ||||
|   } | ||||
| 
 | ||||
|   /** | ||||
|    * Test month argument. | ||||
|    * | ||||
|    * @see \Drupal\datetime\Plugin\views\argument\MonthDate | ||||
|    */ | ||||
|   public function testDatetimeArgumentMonth() { | ||||
|     $view = Views::getView('test_argument_datetime'); | ||||
|     // The 'embed_1' display has the 'month' argument.
 | ||||
|     $view->setDisplay('embed_1'); | ||||
| 
 | ||||
|     $this->executeView($view, ['10']); | ||||
|     $expected = []; | ||||
|     $expected[] = ['nid' => $this->nodes[0]->id()]; | ||||
|     $expected[] = ['nid' => $this->nodes[1]->id()]; | ||||
|     $this->assertIdenticalResultset($view, $expected, $this->map); | ||||
|     $view->destroy(); | ||||
| 
 | ||||
|     $view->setDisplay('embed_1'); | ||||
|     $this->executeView($view, ['01']); | ||||
|     $expected = []; | ||||
|     $expected[] = ['nid' => $this->nodes[2]->id()]; | ||||
|     $this->assertIdenticalResultset($view, $expected, $this->map); | ||||
|     $view->destroy(); | ||||
|   } | ||||
| 
 | ||||
|   /** | ||||
|    * Test day argument. | ||||
|    * | ||||
|    * @see \Drupal\datetime\Plugin\views\argument\DayDate | ||||
|    */ | ||||
|   public function testDatetimeArgumentDay() { | ||||
|     $view = Views::getView('test_argument_datetime'); | ||||
| 
 | ||||
|     // The 'embed_2' display has the 'day' argument.
 | ||||
|     $view->setDisplay('embed_2'); | ||||
|     $this->executeView($view, ['10']); | ||||
|     $expected = []; | ||||
|     $expected[] = ['nid' => $this->nodes[0]->id()]; | ||||
|     $expected[] = ['nid' => $this->nodes[1]->id()]; | ||||
|     $this->assertIdenticalResultset($view, $expected, $this->map); | ||||
|     $view->destroy(); | ||||
| 
 | ||||
|     $view->setDisplay('embed_2'); | ||||
|     $this->executeView($view, ['01']); | ||||
|     $expected = []; | ||||
|     $expected[] = ['nid' => $this->nodes[2]->id()]; | ||||
|     $this->assertIdenticalResultset($view, $expected, $this->map); | ||||
|     $view->destroy(); | ||||
|   } | ||||
| 
 | ||||
|   /** | ||||
|    * Test year, month, and day arguments combined. | ||||
|    */ | ||||
|   public function testDatetimeArgumentAll() { | ||||
|     $view = Views::getView('test_argument_datetime'); | ||||
|     // The 'embed_3' display has year, month, and day arguments.
 | ||||
|     $view->setDisplay('embed_3'); | ||||
| 
 | ||||
|     $this->executeView($view, ['2000', '10', '10']); | ||||
|     $expected = []; | ||||
|     $expected[] = ['nid' => $this->nodes[0]->id()]; | ||||
|     $this->assertIdenticalResultset($view, $expected, $this->map); | ||||
|     $view->destroy(); | ||||
| 
 | ||||
|     $view->setDisplay('embed_3'); | ||||
|     $this->executeView($view, ['2002', '01', '01']); | ||||
|     $expected = []; | ||||
|     $expected[] = ['nid' => $this->nodes[2]->id()]; | ||||
|     $this->assertIdenticalResultset($view, $expected, $this->map); | ||||
|     $view->destroy(); | ||||
|   } | ||||
| 
 | ||||
| } | ||||
|  | @ -0,0 +1,78 @@ | |||
| <?php | ||||
| 
 | ||||
| /** | ||||
|  * @file | ||||
|  * Contains \Drupal\datetime\Tests\Views\DateTimeHandlerTestBase. | ||||
|  */ | ||||
| 
 | ||||
| namespace Drupal\datetime\Tests\Views; | ||||
| 
 | ||||
| use Drupal\datetime\Plugin\Field\FieldType\DateTimeItem; | ||||
| use Drupal\views\Tests\Handler\HandlerTestBase; | ||||
| use Drupal\views\Tests\ViewTestData; | ||||
| 
 | ||||
| /** | ||||
|  * Base class for testing datetime handlers. | ||||
|  */ | ||||
| abstract class DateTimeHandlerTestBase extends HandlerTestBase { | ||||
| 
 | ||||
|   /** | ||||
|    * {@inheritdoc} | ||||
|    */ | ||||
|   public static $modules = ['datetime_test', 'node', 'datetime']; | ||||
| 
 | ||||
|   /** | ||||
|    * Name of the field. | ||||
|    * | ||||
|    * Note, this is used in the default test view. | ||||
|    * | ||||
|    * @var string | ||||
|    */ | ||||
|   protected static $field_name = 'field_date'; | ||||
| 
 | ||||
|   /** | ||||
|    * Nodes to test. | ||||
|    * | ||||
|    * @var \Drupal\node\NodeInterface[] | ||||
|    */ | ||||
|   protected $nodes = []; | ||||
| 
 | ||||
|   /** | ||||
|    * {@inheritdoc} | ||||
|    */ | ||||
|   public function setUp() { | ||||
|     parent::setUp(); | ||||
| 
 | ||||
|     // Add a date field to page nodes.
 | ||||
|     $node_type = entity_create('node_type', [ | ||||
|       'type' => 'page', | ||||
|       'name' => 'page' | ||||
|     ]); | ||||
|     $node_type->save(); | ||||
|     $fieldStorage = entity_create('field_storage_config', [ | ||||
|       'field_name' => static::$field_name, | ||||
|       'entity_type' => 'node', | ||||
|       'type' => 'datetime', | ||||
|       'settings' => ['datetime_type' => DateTimeItem::DATETIME_TYPE_DATETIME], | ||||
|     ]); | ||||
|     $fieldStorage->save(); | ||||
|     $field = entity_create('field_config', [ | ||||
|       'field_storage' => $fieldStorage, | ||||
|       'bundle' => 'page', | ||||
|       'required' => TRUE, | ||||
|     ]); | ||||
|     $field->save(); | ||||
| 
 | ||||
|     // Views needs to be aware of the new field.
 | ||||
|     $this->container->get('views.views_data')->clear(); | ||||
| 
 | ||||
|     // Set column map.
 | ||||
|     $this->map = [ | ||||
|       'nid' => 'nid', | ||||
|     ]; | ||||
| 
 | ||||
|     // Load test views.
 | ||||
|     ViewTestData::createTestViews(get_class($this), ['datetime_test']); | ||||
|   } | ||||
| 
 | ||||
| } | ||||
							
								
								
									
										115
									
								
								core/modules/datetime/src/Tests/Views/FilterDateTest.php
									
										
									
									
									
										Normal file
									
								
							
							
						
						
									
										115
									
								
								core/modules/datetime/src/Tests/Views/FilterDateTest.php
									
										
									
									
									
										Normal file
									
								
							|  | @ -0,0 +1,115 @@ | |||
| <?php | ||||
| 
 | ||||
| /** | ||||
|  * @file | ||||
|  * Contains \Drupal\datetime\Tests\Views\FilterDateTest. | ||||
|  */ | ||||
| 
 | ||||
| namespace Drupal\datetime\Tests\Views; | ||||
| use Drupal\datetime\Plugin\Field\FieldType\DateTimeItem; | ||||
| use Drupal\field\Entity\FieldStorageConfig; | ||||
| use Drupal\views\Views; | ||||
| 
 | ||||
| /** | ||||
|  * Tests date-only fields. | ||||
|  * | ||||
|  * @group datetime | ||||
|  */ | ||||
| class FilterDateTest extends DateTimeHandlerTestBase { | ||||
| 
 | ||||
|   /** | ||||
|    * {@inheritdoc} | ||||
|    */ | ||||
|   public static $testViews = ['test_filter_datetime']; | ||||
| 
 | ||||
|   /** | ||||
|    * For offset tests, set to the current time. | ||||
|    */ | ||||
|   protected static $date; | ||||
| 
 | ||||
|   /** | ||||
|    * {@inheritdoc} | ||||
|    * | ||||
|    * Create nodes with relative dates of yesterday, today, and tomorrow. | ||||
|    */ | ||||
|   public function setUp() { | ||||
|     parent::setUp(); | ||||
| 
 | ||||
|     // Set to 'today'.
 | ||||
|     static::$date = REQUEST_TIME; | ||||
| 
 | ||||
|     // Change field storage to date-only.
 | ||||
|     $storage = FieldStorageConfig::load('node.' . static::$field_name); | ||||
|     $storage->setSetting('datetime_type', DateTimeItem::DATETIME_TYPE_DATE); | ||||
|     $storage->save(); | ||||
| 
 | ||||
|     $dates = [ | ||||
|       // Tomorrow.
 | ||||
|       \Drupal::service('date.formatter')->format(static::$date + 86400, 'custom', DATETIME_DATE_STORAGE_FORMAT, DATETIME_STORAGE_TIMEZONE), | ||||
|       // Today.
 | ||||
|       \Drupal::service('date.formatter')->format(static::$date, 'custom', DATETIME_DATE_STORAGE_FORMAT, DATETIME_STORAGE_TIMEZONE), | ||||
|       // Yesterday.
 | ||||
|       \Drupal::service('date.formatter')->format(static::$date - 86400, 'custom', DATETIME_DATE_STORAGE_FORMAT, DATETIME_STORAGE_TIMEZONE), | ||||
|     ]; | ||||
| 
 | ||||
|     foreach ($dates as $date) { | ||||
|       $this->nodes[] = $this->drupalCreateNode([ | ||||
|         'field_date' => [ | ||||
|           'value' => $date, | ||||
|         ] | ||||
|       ]); | ||||
|     } | ||||
|   } | ||||
| 
 | ||||
|   /** | ||||
|    * Test offsets with date-only fields. | ||||
|    */ | ||||
|   public function testDateOffsets() { | ||||
|     $view = Views::getView('test_filter_datetime'); | ||||
|     $field = static::$field_name . '_value'; | ||||
| 
 | ||||
|     // Test simple operations.
 | ||||
|     $view->initHandlers(); | ||||
| 
 | ||||
|     // A greater than or equal to 'now', should return the 'today' and
 | ||||
|     // the 'tomorrow' node.
 | ||||
|     $view->filter[$field]->operator = '>='; | ||||
|     $view->filter[$field]->value['type'] = 'offset'; | ||||
|     $view->filter[$field]->value['value'] = 'now'; | ||||
|     $view->setDisplay('default'); | ||||
|     $this->executeView($view); | ||||
|     $expected_result = [ | ||||
|       ['nid' => $this->nodes[0]->id()], | ||||
|       ['nid' => $this->nodes[1]->id()], | ||||
|     ]; | ||||
|     $this->assertIdenticalResultset($view, $expected_result, $this->map); | ||||
|     $view->destroy(); | ||||
| 
 | ||||
|     // Only dates in the past.
 | ||||
|     $view->initHandlers(); | ||||
|     $view->filter[$field]->operator = '<'; | ||||
|     $view->filter[$field]->value['type'] = 'offset'; | ||||
|     $view->filter[$field]->value['value'] = 'now'; | ||||
|     $view->setDisplay('default'); | ||||
|     $this->executeView($view); | ||||
|     $expected_result = [ | ||||
|       ['nid' => $this->nodes[2]->id()], | ||||
|     ]; | ||||
|     $this->assertIdenticalResultset($view, $expected_result, $this->map); | ||||
|     $view->destroy(); | ||||
| 
 | ||||
|     // Test offset for between operator. Only the 'tomorrow' node should appear.
 | ||||
|     $view->initHandlers(); | ||||
|     $view->filter[$field]->operator = 'between'; | ||||
|     $view->filter[$field]->value['type'] = 'offset'; | ||||
|     $view->filter[$field]->value['max'] = '+2 days'; | ||||
|     $view->filter[$field]->value['min'] = '+1 day'; | ||||
|     $view->setDisplay('default'); | ||||
|     $this->executeView($view); | ||||
|     $expected_result = [ | ||||
|       ['nid' => $this->nodes[0]->id()], | ||||
|     ]; | ||||
|     $this->assertIdenticalResultset($view, $expected_result, $this->map); | ||||
|   } | ||||
| 
 | ||||
| } | ||||
							
								
								
									
										195
									
								
								core/modules/datetime/src/Tests/Views/FilterDateTimeTest.php
									
										
									
									
									
										Normal file
									
								
							
							
						
						
									
										195
									
								
								core/modules/datetime/src/Tests/Views/FilterDateTimeTest.php
									
										
									
									
									
										Normal file
									
								
							|  | @ -0,0 +1,195 @@ | |||
| <?php | ||||
| 
 | ||||
| /** | ||||
|  * @file | ||||
|  * Contains \Drupal\datetime\Tests\Views\FilterDateTimeTest. | ||||
|  */ | ||||
| 
 | ||||
| namespace Drupal\datetime\Tests\Views; | ||||
| 
 | ||||
| use Drupal\Core\Datetime\Element\Datetime; | ||||
| use Drupal\views\Views; | ||||
| 
 | ||||
| /** | ||||
|  * Tests the Drupal\datetime\Plugin\views\filter\Date handler. | ||||
|  * | ||||
|  * @group datetime | ||||
|  */ | ||||
| class FilterDateTimeTest extends DateTimeHandlerTestBase { | ||||
| 
 | ||||
|   /** | ||||
|    * {@inheritdoc} | ||||
|    */ | ||||
|   public static $testViews = ['test_filter_datetime']; | ||||
| 
 | ||||
|   /** | ||||
|    * For offset tests, set a date 1 day in the future. | ||||
|    */ | ||||
|   protected static $date; | ||||
| 
 | ||||
|   /** | ||||
|    * Use a non-UTC timezone. | ||||
|    */ | ||||
|   protected static $timezone = 'America/Vancouver'; | ||||
| 
 | ||||
|   /** | ||||
|    * {@inheritdoc} | ||||
|    */ | ||||
|   public function setUp() { | ||||
|     parent::setUp(); | ||||
| 
 | ||||
|     static::$date = REQUEST_TIME + 86400; | ||||
| 
 | ||||
|     // Set the timezone.
 | ||||
|     date_default_timezone_set(static::$timezone); | ||||
| 
 | ||||
|     // Add some basic test nodes.
 | ||||
|     $dates = [ | ||||
|       '2000-10-10T00:01:30', | ||||
|       '2001-10-10T12:12:12', | ||||
|       '2002-10-10T14:14:14', | ||||
|       // The date storage timezone is used (this mimics the steps taken in the
 | ||||
|       // widget: \Drupal\datetime\Plugin\Field\FieldWidget::messageFormValues().
 | ||||
|       \Drupal::service('date.formatter')->format(static::$date, 'custom', DATETIME_DATETIME_STORAGE_FORMAT, DATETIME_STORAGE_TIMEZONE), | ||||
|     ]; | ||||
|     foreach ($dates as $date) { | ||||
|       $this->nodes[] = $this->drupalCreateNode([ | ||||
|         'field_date' => [ | ||||
|           'value' => $date, | ||||
|         ] | ||||
|       ]); | ||||
|     } | ||||
|   } | ||||
| 
 | ||||
|   /** | ||||
|    * Test filter operations. | ||||
|    */ | ||||
|   public function testDatetimeFilter() { | ||||
|     $this->_testOffset(); | ||||
|     $this->_testBetween(); | ||||
|     $this->_testExact(); | ||||
|   } | ||||
| 
 | ||||
|   /** | ||||
|    * Test offset operations. | ||||
|    */ | ||||
|   protected function _testOffset() { | ||||
|     $view = Views::getView('test_filter_datetime'); | ||||
|     $field = static::$field_name . '_value'; | ||||
| 
 | ||||
|     // Test simple operations.
 | ||||
|     $view->initHandlers(); | ||||
| 
 | ||||
|     $view->filter[$field]->operator = '>'; | ||||
|     $view->filter[$field]->value['type'] = 'offset'; | ||||
|     $view->filter[$field]->value['value'] = '+1 hour'; | ||||
|     $view->setDisplay('default'); | ||||
|     $this->executeView($view); | ||||
|     $expected_result = [ | ||||
|       ['nid' => $this->nodes[3]->id()], | ||||
|     ]; | ||||
|     $this->assertIdenticalResultset($view, $expected_result, $this->map); | ||||
|     $view->destroy(); | ||||
| 
 | ||||
|     // Test offset for between operator.
 | ||||
|     $view->initHandlers(); | ||||
|     $view->filter[$field]->operator = 'between'; | ||||
|     $view->filter[$field]->value['type'] = 'offset'; | ||||
|     $view->filter[$field]->value['max'] = '+2 days'; | ||||
|     $view->filter[$field]->value['min'] = '+1 hour'; | ||||
|     $view->setDisplay('default'); | ||||
|     $this->executeView($view); | ||||
|     $expected_result = [ | ||||
|       ['nid' => $this->nodes[3]->id()], | ||||
|     ]; | ||||
|     $this->assertIdenticalResultset($view, $expected_result, $this->map); | ||||
|   } | ||||
| 
 | ||||
|   /** | ||||
|    *  Test between operations. | ||||
|    */ | ||||
|   protected function _testBetween() { | ||||
|     $view = Views::getView('test_filter_datetime'); | ||||
|     $field = static::$field_name . '_value'; | ||||
| 
 | ||||
|     // Test between with min and max.
 | ||||
|     $view->initHandlers(); | ||||
|     $view->filter[$field]->operator = 'between'; | ||||
|     $view->filter[$field]->value['min'] = '2001-01-01'; | ||||
|     $view->filter[$field]->value['max'] = '2002-01-01'; | ||||
|     $view->setDisplay('default'); | ||||
|     $this->executeView($view); | ||||
|     $expected_result = [ | ||||
|       ['nid' => $this->nodes[1]->id()], | ||||
|     ]; | ||||
|     $this->assertIdenticalResultset($view, $expected_result, $this->map); | ||||
|     $view->destroy(); | ||||
| 
 | ||||
|     // Test between with just max.
 | ||||
|     $view->initHandlers(); | ||||
|     $view->filter[$field]->operator = 'between'; | ||||
|     $view->filter[$field]->value['max'] = '2002-01-01'; | ||||
|     $view->setDisplay('default'); | ||||
|     $this->executeView($view); | ||||
|     $expected_result = [ | ||||
|       ['nid' => $this->nodes[0]->id()], | ||||
|       ['nid' => $this->nodes[1]->id()], | ||||
|     ]; | ||||
|     $this->assertIdenticalResultset($view, $expected_result, $this->map); | ||||
|     $view->destroy(); | ||||
| 
 | ||||
|     // Test not between with min and max.
 | ||||
|     $view->initHandlers(); | ||||
|     $view->filter[$field]->operator = 'not between'; | ||||
|     $view->filter[$field]->value['min'] = '2001-01-01'; | ||||
|     $view->filter[$field]->value['max'] = '2002-01-01'; | ||||
|     $view->setDisplay('default'); | ||||
|     $this->executeView($view); | ||||
|     $expected_result = [ | ||||
|       ['nid' => $this->nodes[0]->id()], | ||||
|       ['nid' => $this->nodes[2]->id()], | ||||
|       ['nid' => $this->nodes[3]->id()], | ||||
|     ]; | ||||
|     $this->assertIdenticalResultset($view, $expected_result, $this->map); | ||||
|     $view->destroy(); | ||||
| 
 | ||||
|     // Test not between with just max.
 | ||||
|     $view->initHandlers(); | ||||
|     $view->filter[$field]->operator = 'not between'; | ||||
|     $view->filter[$field]->value['max'] = '2001-01-01'; | ||||
|     $view->setDisplay('default'); | ||||
|     $this->executeView($view); | ||||
|     $expected_result = [ | ||||
|       ['nid' => $this->nodes[1]->id()], | ||||
|       ['nid' => $this->nodes[2]->id()], | ||||
|       ['nid' => $this->nodes[3]->id()], | ||||
|     ]; | ||||
|     $this->assertIdenticalResultset($view, $expected_result, $this->map); | ||||
|   } | ||||
| 
 | ||||
|   /** | ||||
|    * Test exact date matching. | ||||
|    */ | ||||
|   protected function _testExact() { | ||||
|     $view = Views::getView('test_filter_datetime'); | ||||
|     $field = static::$field_name . '_value'; | ||||
| 
 | ||||
|     // Test between with min and max.
 | ||||
|     $view->initHandlers(); | ||||
|     $view->filter[$field]->operator = '='; | ||||
|     $view->filter[$field]->value['min'] = ''; | ||||
|     $view->filter[$field]->value['max'] = ''; | ||||
|     // Use the date from node 3. Use the site timezone (mimics a value entered
 | ||||
|     // through the UI).
 | ||||
|     $view->filter[$field]->value['value'] = \Drupal::service('date.formatter')->format(static::$date, 'custom', DATETIME_DATETIME_STORAGE_FORMAT, static::$timezone); | ||||
|     $view->setDisplay('default'); | ||||
|     $this->executeView($view); | ||||
|     $expected_result = [ | ||||
|       ['nid' => $this->nodes[3]->id()], | ||||
|     ]; | ||||
|     $this->assertIdenticalResultset($view, $expected_result, $this->map); | ||||
|     $view->destroy(); | ||||
| 
 | ||||
|   } | ||||
| 
 | ||||
| } | ||||
							
								
								
									
										99
									
								
								core/modules/datetime/src/Tests/Views/SortDateTimeTest.php
									
										
									
									
									
										Normal file
									
								
							
							
						
						
									
										99
									
								
								core/modules/datetime/src/Tests/Views/SortDateTimeTest.php
									
										
									
									
									
										Normal file
									
								
							|  | @ -0,0 +1,99 @@ | |||
| <?php | ||||
| 
 | ||||
| /** | ||||
|  * @file | ||||
|  * Contains \Drupal\datetime\Tests\Views\SortDateTimeTest. | ||||
|  */ | ||||
| 
 | ||||
| namespace Drupal\datetime\Tests\Views; | ||||
| 
 | ||||
| use Drupal\views\Views; | ||||
| 
 | ||||
| /** | ||||
|  * Tests for core Drupal\datetime\Plugin\views\sort\Date handler. | ||||
|  * | ||||
|  * @group datetime | ||||
|  */ | ||||
| class SortDateTimeTest extends DateTimeHandlerTestBase { | ||||
| 
 | ||||
|   /** | ||||
|    * {@inheritdoc} | ||||
|    */ | ||||
|   public static $testViews = ['test_sort_datetime']; | ||||
| 
 | ||||
|   /** | ||||
|    * {@inheritdoc} | ||||
|    */ | ||||
|   public function setUp() { | ||||
|     parent::setUp(); | ||||
| 
 | ||||
|     // Add some basic test nodes.
 | ||||
|     $dates = [ | ||||
|       '2014-10-10T00:03:00', | ||||
|       '2000-10-10T00:01:00', | ||||
|       '2000-10-10T00:02:00', | ||||
|       '2000-10-10T00:03:00', | ||||
|     ]; | ||||
|     foreach ($dates as $date) { | ||||
|       $this->nodes[] = $this->drupalCreateNode([ | ||||
|         'field_date' => [ | ||||
|           'value' => $date, | ||||
|         ] | ||||
|       ]); | ||||
|     } | ||||
|   } | ||||
| 
 | ||||
|   /** | ||||
|    * Tests the datetime sort handler. | ||||
|    */ | ||||
|   public function testDateTimeSort() { | ||||
|     $field = static::$field_name . '_value'; | ||||
|     $view = Views::getView('test_sort_datetime'); | ||||
| 
 | ||||
|     // Sort order is DESC.
 | ||||
|     $view->initHandlers(); | ||||
|     $view->sort[$field]->options['granularity'] = 'minute'; | ||||
|     $view->setDisplay('default'); | ||||
|     $this->executeView($view); | ||||
|     $expected_result = [ | ||||
|       ['nid' => $this->nodes[0]->id()], | ||||
|       ['nid' => $this->nodes[3]->id()], | ||||
|       ['nid' => $this->nodes[2]->id()], | ||||
|       ['nid' => $this->nodes[1]->id()], | ||||
|     ]; | ||||
|     $this->assertIdenticalResultset($view, $expected_result, $this->map); | ||||
|     $view->destroy(); | ||||
| 
 | ||||
|     // Check ASC.
 | ||||
|     $view->initHandlers(); | ||||
|     $field = static::$field_name . '_value'; | ||||
|     $view->sort[$field]->options['order'] = 'ASC'; | ||||
|     $view->setDisplay('default'); | ||||
|     $this->executeView($view); | ||||
|     $expected_result = [ | ||||
|       ['nid' => $this->nodes[1]->id()], | ||||
|       ['nid' => $this->nodes[2]->id()], | ||||
|       ['nid' => $this->nodes[3]->id()], | ||||
|       ['nid' => $this->nodes[0]->id()], | ||||
|     ]; | ||||
|     $this->assertIdenticalResultset($view, $expected_result, $this->map); | ||||
|     $view->destroy(); | ||||
| 
 | ||||
|     // Change granularity to 'year', and the secondary node ID order should
 | ||||
|     // define the order of nodes with the same year.
 | ||||
|     $view->initHandlers(); | ||||
|     $view->sort[$field]->options['granularity'] = 'year'; | ||||
|     $view->sort[$field]->options['order'] = 'DESC'; | ||||
|     $view->setDisplay('default'); | ||||
|     $this->executeView($view); | ||||
|     $expected_result = [ | ||||
|       ['nid' => $this->nodes[0]->id()], | ||||
|       ['nid' => $this->nodes[1]->id()], | ||||
|       ['nid' => $this->nodes[2]->id()], | ||||
|       ['nid' => $this->nodes[3]->id()], | ||||
|     ]; | ||||
|     $this->assertIdenticalResultset($view, $expected_result, $this->map); | ||||
|     $view->destroy(); | ||||
|   } | ||||
| 
 | ||||
| } | ||||
		Reference in a new issue
	
	 Pantheon Automation
						Pantheon Automation