3 namespace Drupal\Tests\datetime\Kernel\Views;
5 use Drupal\datetime\Plugin\Field\FieldType\DateTimeItemInterface;
6 use Drupal\node\Entity\Node;
7 use Drupal\views\Views;
10 * Tests the Drupal\datetime\Plugin\views\filter\Date handler.
14 class FilterDateTimeTest extends DateTimeHandlerTestBase {
19 public static $testViews = ['test_filter_datetime'];
22 * For offset tests, set a date 1 day in the future.
24 protected static $date;
27 * Use a non-UTC timezone.
31 protected static $timezone = 'America/Vancouver';
36 protected function setUp($import_test_views = TRUE) {
37 parent::setUp($import_test_views);
39 static::$date = REQUEST_TIME + 86400;
42 date_default_timezone_set(static::$timezone);
43 $this->config('system.date')
44 ->set('timezone.default', static::$timezone)
47 // Add some basic test nodes.
49 '2000-10-10T00:01:30',
50 '2001-10-10T12:12:12',
51 '2002-10-10T14:14:14',
52 // The date storage timezone is used (this mimics the steps taken in the
53 // widget: \Drupal\datetime\Plugin\Field\FieldWidget::messageFormValues().
54 \Drupal::service('date.formatter')->format(static::$date, 'custom', DateTimeItemInterface::DATETIME_STORAGE_FORMAT, DateTimeItemInterface::STORAGE_TIMEZONE),
56 foreach ($dates as $date) {
57 $node = Node::create([
58 'title' => $this->randomMachineName(8),
65 $this->nodes[] = $node;
70 * Test filter operations.
72 public function testDatetimeFilter() {
74 $this->_testBetween();
79 * Test offset operations.
81 protected function _testOffset() {
82 $view = Views::getView('test_filter_datetime');
83 $field = static::$field_name . '_value';
85 // Test simple operations.
86 $view->initHandlers();
88 $view->filter[$field]->operator = '>';
89 $view->filter[$field]->value['type'] = 'offset';
90 $view->filter[$field]->value['value'] = '+1 hour';
91 $view->setDisplay('default');
92 $this->executeView($view);
94 ['nid' => $this->nodes[3]->id()],
96 $this->assertIdenticalResultset($view, $expected_result, $this->map);
99 // Test offset for between operator.
100 $view->initHandlers();
101 $view->filter[$field]->operator = 'between';
102 $view->filter[$field]->value['type'] = 'offset';
103 $view->filter[$field]->value['max'] = '+2 days';
104 $view->filter[$field]->value['min'] = '+1 hour';
105 $view->setDisplay('default');
106 $this->executeView($view);
108 ['nid' => $this->nodes[3]->id()],
110 $this->assertIdenticalResultset($view, $expected_result, $this->map);
114 * Test between operations.
116 protected function _testBetween() {
117 $view = Views::getView('test_filter_datetime');
118 $field = static::$field_name . '_value';
120 // Test between with min and max.
121 $view->initHandlers();
122 $view->filter[$field]->operator = 'between';
123 $view->filter[$field]->value['min'] = '2001-01-01';
124 $view->filter[$field]->value['max'] = '2002-01-01';
125 $view->setDisplay('default');
126 $this->executeView($view);
128 ['nid' => $this->nodes[1]->id()],
130 $this->assertIdenticalResultset($view, $expected_result, $this->map);
133 // Test between with just max.
134 $view->initHandlers();
135 $view->filter[$field]->operator = 'between';
136 $view->filter[$field]->value['max'] = '2002-01-01';
137 $view->setDisplay('default');
138 $this->executeView($view);
140 ['nid' => $this->nodes[0]->id()],
141 ['nid' => $this->nodes[1]->id()],
143 $this->assertIdenticalResultset($view, $expected_result, $this->map);
146 // Test not between with min and max.
147 $view->initHandlers();
148 $view->filter[$field]->operator = 'not between';
149 $view->filter[$field]->value['min'] = '2001-01-01';
150 // Set maximum date to date of node 1 to test range borders.
151 $view->filter[$field]->value['max'] = '2001-10-10T12:12:12';
152 $view->setDisplay('default');
153 $this->executeView($view);
155 ['nid' => $this->nodes[0]->id()],
156 ['nid' => $this->nodes[2]->id()],
157 ['nid' => $this->nodes[3]->id()],
159 $this->assertIdenticalResultset($view, $expected_result, $this->map);
162 // Test not between with just max.
163 $view->initHandlers();
164 $view->filter[$field]->operator = 'not between';
165 $view->filter[$field]->value['max'] = '2001-01-01';
166 $view->setDisplay('default');
167 $this->executeView($view);
169 ['nid' => $this->nodes[1]->id()],
170 ['nid' => $this->nodes[2]->id()],
171 ['nid' => $this->nodes[3]->id()],
173 $this->assertIdenticalResultset($view, $expected_result, $this->map);
177 * Test exact date matching.
179 protected function _testExact() {
180 $view = Views::getView('test_filter_datetime');
181 $field = static::$field_name . '_value';
183 // Test between with min and max.
184 $view->initHandlers();
185 $view->filter[$field]->operator = '=';
186 $view->filter[$field]->value['min'] = '';
187 $view->filter[$field]->value['max'] = '';
188 // Use the date from node 3. Use the site timezone (mimics a value entered
190 $view->filter[$field]->value['value'] = \Drupal::service('date.formatter')->format(static::$date, 'custom', DateTimeItemInterface::DATETIME_STORAGE_FORMAT, static::$timezone);
191 $view->setDisplay('default');
192 $this->executeView($view);
194 ['nid' => $this->nodes[3]->id()],
196 $this->assertIdenticalResultset($view, $expected_result, $this->map);