Pull merge.
[yaffs-website] / web / core / modules / datetime_range / tests / fixtures / update / datetime_range-filter-values.php
1 <?php
2 // @codingStandardsIgnoreFile
3
4 /**
5  * @file
6  * Contains database additions to drupal-8.bare.standard.php.gz for testing the
7  * upgrade path of https://www.drupal.org/node/2786577.
8  */
9
10 use Drupal\Core\Database\Database;
11 use Drupal\Core\Serialization\Yaml;
12
13 $connection = Database::getConnection();
14
15 // Configuration for an datetime_range field storage.
16 $field_storage_datetime_range = Yaml::decode(file_get_contents(__DIR__ . '/field.storage.node.field_range.yml'));
17
18 // Configuration for a datetime_range field on 'page' node bundle.
19 $field_datetime_range = Yaml::decode(file_get_contents(__DIR__ . '/field.field.node.page.field_range.yml'));
20
21 // Configuration for a View using datetime_range plugins.
22 $views_datetime_range = Yaml::decode(file_get_contents(__DIR__ . '/views.view.test_datetime_range_filter_values.yml'));
23
24 // Update core.entity_form_display.node.page.default
25 $data = $connection->select('config')
26   ->fields('config', ['data'])
27   ->condition('collection', '')
28   ->condition('name', 'core.entity_form_display.node.page.default')
29   ->execute()
30   ->fetchField();
31
32 $data = unserialize($data);
33 $data['dependencies']['config'][] = 'field.field.' . $field_datetime_range['id'];
34 $data['dependencies']['module'][] = 'datetime_range';
35 $data['content'][$field_datetime_range['field_name']] = array(
36     "weight"=> 27,
37     "settings" => array(),
38     "third_party_settings" => array(),
39     "type" => "daterange_default",
40     "region" => "content"
41 );
42 $connection->update('config')
43   ->fields([
44     'data' => serialize($data),
45   ])
46   ->condition('collection', '')
47   ->condition('name', 'core.entity_form_display.node.page.default')
48   ->execute();
49
50 // Update core.entity_view_display.node.page.default
51 $data = $connection->select('config')
52   ->fields('config', ['data'])
53   ->condition('collection', '')
54   ->condition('name', 'core.entity_view_display.node.page.default')
55   ->execute()
56   ->fetchField();
57
58 $data = unserialize($data);
59 $data['dependencies']['config'][] = 'field.field.' . $field_datetime_range['id'];
60 $data['dependencies']['module'][] = 'datetime_range';
61 $data['content'][$field_datetime_range['field_name']] = array(
62     "weight"=> 102,
63     "label"=> "above",
64     "settings" => array("separator"=> "-", "format_type" => "medium", "timezone_override" => ""),
65     "third_party_settings" => array(),
66     "type" => "daterange_default",
67     "region" => "content"
68 );
69 $connection->update('config')
70   ->fields([
71     'data' => serialize($data),
72   ])
73   ->condition('collection', '')
74   ->condition('name', 'core.entity_view_display.node.page.default')
75   ->execute();
76
77 $connection->insert('config')
78 ->fields(array(
79   'collection',
80   'name',
81   'data',
82 ))
83 ->values(array(
84   'collection' => '',
85   'name' => 'field.field.' . $field_datetime_range['id'],
86   'data' => serialize($field_datetime_range),
87 ))
88 ->values(array(
89   'collection' => '',
90   'name' => 'field.storage.' . $field_storage_datetime_range['id'],
91   'data' => serialize($field_storage_datetime_range),
92 ))
93 ->values(array(
94   'collection' => '',
95   'name' => 'views.view.' . $views_datetime_range['id'],
96   'data' => serialize($views_datetime_range),
97 ))
98 ->execute();
99
100 // Update core.extension.
101 $extensions = $connection->select('config')
102   ->fields('config', ['data'])
103   ->condition('collection', '')
104   ->condition('name', 'core.extension')
105   ->execute()
106   ->fetchField();
107 $extensions = unserialize($extensions);
108 $extensions['module']['datetime_range'] = 0;
109 $connection->update('config')
110   ->fields([
111     'data' => serialize($extensions),
112   ])
113   ->condition('collection', '')
114   ->condition('name', 'core.extension')
115   ->execute();
116
117 $connection->insert('key_value')
118 ->fields(array(
119   'collection',
120   'name',
121   'value',
122 ))
123 ->values(array(
124   'collection' => 'config.entity.key_store.field_config',
125   'name' => 'uuid:87dc4221-8d56-4112-8a7f-7a855ac35d08',
126   'value' => 'a:1:{i:0;s:33:"field.field.' . $field_datetime_range['id'] . '";}',
127 ))
128 ->values(array(
129   'collection' => 'config.entity.key_store.field_storage_config',
130   'name' => 'uuid:2190ad8c-39dd-4eb1-b189-1bfc0c244a40',
131   'value' => 'a:1:{i:0;s:30:"field.storage.' . $field_storage_datetime_range['id'] . '";}',
132 ))
133 ->values(array(
134   'collection' => 'config.entity.key_store.view',
135   'name' => 'uuid:d20760b6-7cc4-4844-ae04-96da7225a46f',
136   'value' => 'a:1:{i:0;s:44:"views.view.' . $views_datetime_range['id'] . '";}',
137 ))
138 ->values(array(
139   'collection' => 'entity.storage_schema.sql',
140   'name' => 'node.field_schema_data.field_range',
141   'value' => 'a:2:{s:17:"node__field_range";a:4:{s:11:"description";s:40:"Data storage for node field field_range.";s:6:"fields";a:8:{s:6:"bundle";a:5:{s:4:"type";s:13:"varchar_ascii";s:6:"length";i:128;s:8:"not null";b:1;s:7:"default";s:0:"";s:11:"description";s:88:"The field instance bundle to which this row belongs, used when deleting a field instance";}s:7:"deleted";a:5:{s:4:"type";s:3:"int";s:4:"size";s:4:"tiny";s:8:"not null";b:1;s:7:"default";i:0;s:11:"description";s:60:"A boolean indicating whether this data item has been deleted";}s:9:"entity_id";a:4:{s:4:"type";s:3:"int";s:8:"unsigned";b:1;s:8:"not null";b:1;s:11:"description";s:38:"The entity id this data is attached to";}s:11:"revision_id";a:4:{s:4:"type";s:3:"int";s:8:"unsigned";b:1;s:8:"not null";b:1;s:11:"description";s:47:"The entity revision id this data is attached to";}s:8:"langcode";a:5:{s:4:"type";s:13:"varchar_ascii";s:6:"length";i:32;s:8:"not null";b:1;s:7:"default";s:0:"";s:11:"description";s:37:"The language code for this data item.";}s:5:"delta";a:4:{s:4:"type";s:3:"int";s:8:"unsigned";b:1;s:8:"not null";b:1;s:11:"description";s:67:"The sequence number for this data item, used for multi-value fields";}s:17:"field_range_value";a:4:{s:11:"description";s:21:"The start date value.";s:4:"type";s:7:"varchar";s:6:"length";i:20;s:8:"not null";b:1;}s:21:"field_range_end_value";a:4:{s:11:"description";s:19:"The end date value.";s:4:"type";s:7:"varchar";s:6:"length";i:20;s:8:"not null";b:1;}}s:11:"primary key";a:4:{i:0;s:9:"entity_id";i:1;s:7:"deleted";i:2;s:5:"delta";i:3;s:8:"langcode";}s:7:"indexes";a:4:{s:6:"bundle";a:1:{i:0;s:6:"bundle";}s:11:"revision_id";a:1:{i:0;s:11:"revision_id";}s:17:"field_range_value";a:1:{i:0;s:17:"field_range_value";}s:21:"field_range_end_value";a:1:{i:0;s:21:"field_range_end_value";}}}s:26:"node_revision__field_range";a:4:{s:11:"description";s:52:"Revision archive storage for node field field_range.";s:6:"fields";a:8:{s:6:"bundle";a:5:{s:4:"type";s:13:"varchar_ascii";s:6:"length";i:128;s:8:"not null";b:1;s:7:"default";s:0:"";s:11:"description";s:88:"The field instance bundle to which this row belongs, used when deleting a field instance";}s:7:"deleted";a:5:{s:4:"type";s:3:"int";s:4:"size";s:4:"tiny";s:8:"not null";b:1;s:7:"default";i:0;s:11:"description";s:60:"A boolean indicating whether this data item has been deleted";}s:9:"entity_id";a:4:{s:4:"type";s:3:"int";s:8:"unsigned";b:1;s:8:"not null";b:1;s:11:"description";s:38:"The entity id this data is attached to";}s:11:"revision_id";a:4:{s:4:"type";s:3:"int";s:8:"unsigned";b:1;s:8:"not null";b:1;s:11:"description";s:47:"The entity revision id this data is attached to";}s:8:"langcode";a:5:{s:4:"type";s:13:"varchar_ascii";s:6:"length";i:32;s:8:"not null";b:1;s:7:"default";s:0:"";s:11:"description";s:37:"The language code for this data item.";}s:5:"delta";a:4:{s:4:"type";s:3:"int";s:8:"unsigned";b:1;s:8:"not null";b:1;s:11:"description";s:67:"The sequence number for this data item, used for multi-value fields";}s:17:"field_range_value";a:4:{s:11:"description";s:21:"The start date value.";s:4:"type";s:7:"varchar";s:6:"length";i:20;s:8:"not null";b:1;}s:21:"field_range_end_value";a:4:{s:11:"description";s:19:"The end date value.";s:4:"type";s:7:"varchar";s:6:"length";i:20;s:8:"not null";b:1;}}s:11:"primary key";a:5:{i:0;s:9:"entity_id";i:1;s:11:"revision_id";i:2;s:7:"deleted";i:3;s:5:"delta";i:4;s:8:"langcode";}s:7:"indexes";a:4:{s:6:"bundle";a:1:{i:0;s:6:"bundle";}s:11:"revision_id";a:1:{i:0;s:11:"revision_id";}s:17:"field_range_value";a:1:{i:0;s:17:"field_range_value";}s:21:"field_range_end_value";a:1:{i:0;s:21:"field_range_end_value";}}}}',
142 ))
143 ->values(array(
144   'collection' => 'system.schema',
145   'name' => 'datetime_range',
146   'value' => 'i:8000;',
147 ))
148 ->execute();
149
150 // Update entity.definitions.bundle_field_map
151 $value = $connection->select('key_value')
152   ->fields('key_value', ['value'])
153   ->condition('collection', 'entity.definitions.bundle_field_map')
154   ->condition('name', 'node')
155   ->execute()
156   ->fetchField();
157
158 $value = unserialize($value);
159 $value["field_range"] = array("type" => "daterange", "bundles" => array("page" => "page"));
160
161 $connection->update('key_value')
162   ->fields([
163     'value' => serialize($value),
164   ])
165   ->condition('collection', 'entity.definitions.bundle_field_map')
166   ->condition('name', 'node')
167   ->execute();
168
169 // Update system.module.files
170 $files = $connection->select('key_value')
171   ->fields('key_value', ['value'])
172   ->condition('collection', 'state')
173   ->condition('name', 'system.module.files')
174   ->execute()
175   ->fetchField();
176
177 $files = unserialize($files);
178 $files["datetime_range"] = "core/modules/datetime_range/datetime_range.info.yml";
179
180 $connection->update('key_value')
181   ->fields([
182     'value' => serialize($files),
183   ])
184   ->condition('collection', 'state')
185   ->condition('name', 'system.module.files')
186   ->execute();
187
188 $connection->schema()->createTable('node__field_range', array(
189   'fields' => array(
190     'bundle' => array(
191       'type' => 'varchar_ascii',
192       'not null' => TRUE,
193       'length' => '128',
194       'default' => '',
195     ),
196     'deleted' => array(
197       'type' => 'int',
198       'not null' => TRUE,
199       'size' => 'tiny',
200       'default' => '0',
201     ),
202     'entity_id' => array(
203       'type' => 'int',
204       'not null' => TRUE,
205       'size' => 'normal',
206       'unsigned' => TRUE,
207     ),
208     'revision_id' => array(
209       'type' => 'int',
210       'not null' => TRUE,
211       'size' => 'normal',
212       'unsigned' => TRUE,
213     ),
214     'langcode' => array(
215       'type' => 'varchar_ascii',
216       'not null' => TRUE,
217       'length' => '32',
218       'default' => '',
219     ),
220     'delta' => array(
221       'type' => 'int',
222       'not null' => TRUE,
223       'size' => 'normal',
224       'unsigned' => TRUE,
225     ),
226     'field_range_value' => array(
227       'type' => 'varchar',
228       'not null' => TRUE,
229       'length' => '20',
230     ),
231     'field_range_end_value' => array(
232       'type' => 'varchar',
233       'not null' => TRUE,
234       'length' => '20',
235     ),
236   ),
237   'primary key' => array(
238     'entity_id',
239     'deleted',
240     'delta',
241     'langcode',
242   ),
243   'indexes' => array(
244     'bundle' => array(
245       'bundle',
246     ),
247     'revision_id' => array(
248       'revision_id',
249     ),
250     'field_range_value' => array(
251       'field_range_value',
252     ),
253     'field_range_end_value' => array(
254       'field_range_end_value',
255     ),
256   ),
257   'mysql_character_set' => 'utf8mb4',
258 ));
259
260 $connection->schema()->createTable('node_revision__field_range', array(
261   'fields' => array(
262     'bundle' => array(
263       'type' => 'varchar_ascii',
264       'not null' => TRUE,
265       'length' => '128',
266       'default' => '',
267     ),
268     'deleted' => array(
269       'type' => 'int',
270       'not null' => TRUE,
271       'size' => 'tiny',
272       'default' => '0',
273     ),
274     'entity_id' => array(
275       'type' => 'int',
276       'not null' => TRUE,
277       'size' => 'normal',
278       'unsigned' => TRUE,
279     ),
280     'revision_id' => array(
281       'type' => 'int',
282       'not null' => TRUE,
283       'size' => 'normal',
284       'unsigned' => TRUE,
285     ),
286     'langcode' => array(
287       'type' => 'varchar_ascii',
288       'not null' => TRUE,
289       'length' => '32',
290       'default' => '',
291     ),
292     'delta' => array(
293       'type' => 'int',
294       'not null' => TRUE,
295       'size' => 'normal',
296       'unsigned' => TRUE,
297     ),
298     'field_range_value' => array(
299       'type' => 'varchar',
300       'not null' => TRUE,
301       'length' => '20',
302     ),
303     'field_range_end_value' => array(
304       'type' => 'varchar',
305       'not null' => TRUE,
306       'length' => '20',
307     ),
308   ),
309   'primary key' => array(
310     'entity_id',
311     'revision_id',
312     'deleted',
313     'delta',
314     'langcode',
315   ),
316   'indexes' => array(
317     'bundle' => array(
318       'bundle',
319     ),
320     'revision_id' => array(
321       'revision_id',
322     ),
323     'field_range_value' => array(
324       'field_range_value',
325     ),
326     'field_range_end_value' => array(
327       'field_range_end_value',
328     ),
329   ),
330   'mysql_character_set' => 'utf8mb4',
331 ));
332