c0dc97bc7b56297ab700c89015faaba90416c901
[yaffs-website] / web / core / modules / config / src / Tests / ConfigEntityTest.php
1 <?php
2
3 namespace Drupal\config\Tests;
4
5 use Drupal\Component\Utility\SafeMarkup;
6 use Drupal\Core\Entity\EntityMalformedException;
7 use Drupal\Core\Entity\EntityStorageException;
8 use Drupal\Core\Config\Entity\ConfigEntityStorage;
9 use Drupal\Core\Config\Entity\Exception\ConfigEntityIdLengthException;
10 use Drupal\Core\Url;
11 use Drupal\simpletest\WebTestBase;
12
13 /**
14  * Tests configuration entities.
15  *
16  * @group config
17  */
18 class ConfigEntityTest extends WebTestBase {
19
20   /**
21    * The maximum length for the entity storage used in this test.
22    */
23   const MAX_ID_LENGTH = ConfigEntityStorage::MAX_ID_LENGTH;
24
25   /**
26    * Modules to enable.
27    *
28    * @var array
29    */
30   public static $modules = ['config_test'];
31
32   /**
33    * Tests CRUD operations.
34    */
35   public function testCRUD() {
36     $default_langcode = \Drupal::languageManager()->getDefaultLanguage()->getId();
37     // Verify default properties on a newly created empty entity.
38     $empty = entity_create('config_test');
39     $this->assertTrue($empty->uuid());
40     $this->assertIdentical($empty->label, NULL);
41     $this->assertIdentical($empty->style, NULL);
42     $this->assertIdentical($empty->language()->getId(), $default_langcode);
43
44     // Verify ConfigEntity properties/methods on the newly created empty entity.
45     $this->assertIdentical($empty->isNew(), TRUE);
46     $this->assertIdentical($empty->getOriginalId(), NULL);
47     $this->assertIdentical($empty->bundle(), 'config_test');
48     $this->assertIdentical($empty->id(), NULL);
49     $this->assertTrue($empty->uuid());
50     $this->assertIdentical($empty->label(), NULL);
51
52     $this->assertIdentical($empty->get('id'), NULL);
53     $this->assertTrue($empty->get('uuid'));
54     $this->assertIdentical($empty->get('label'), NULL);
55     $this->assertIdentical($empty->get('style'), NULL);
56     $this->assertIdentical($empty->language()->getId(), $default_langcode);
57
58     // Verify Entity properties/methods on the newly created empty entity.
59     $this->assertIdentical($empty->getEntityTypeId(), 'config_test');
60     // The URI can only be checked after saving.
61     try {
62       $empty->urlInfo();
63       $this->fail('EntityMalformedException was thrown.');
64     }
65     catch (EntityMalformedException $e) {
66       $this->pass('EntityMalformedException was thrown.');
67     }
68
69     // Verify that an empty entity cannot be saved.
70     try {
71       $empty->save();
72       $this->fail('EntityMalformedException was thrown.');
73     }
74     catch (EntityMalformedException $e) {
75       $this->pass('EntityMalformedException was thrown.');
76     }
77
78     // Verify that an entity with an empty ID string is considered empty, too.
79     $empty_id = entity_create('config_test', [
80       'id' => '',
81     ]);
82     $this->assertIdentical($empty_id->isNew(), TRUE);
83     try {
84       $empty_id->save();
85       $this->fail('EntityMalformedException was thrown.');
86     }
87     catch (EntityMalformedException $e) {
88       $this->pass('EntityMalformedException was thrown.');
89     }
90
91     // Verify properties on a newly created entity.
92     $config_test = entity_create('config_test', $expected = [
93       'id' => $this->randomMachineName(),
94       'label' => $this->randomString(),
95       'style' => $this->randomMachineName(),
96     ]);
97     $this->assertTrue($config_test->uuid());
98     $this->assertNotEqual($config_test->uuid(), $empty->uuid());
99     $this->assertIdentical($config_test->label, $expected['label']);
100     $this->assertIdentical($config_test->style, $expected['style']);
101     $this->assertIdentical($config_test->language()->getId(), $default_langcode);
102
103     // Verify methods on the newly created entity.
104     $this->assertIdentical($config_test->isNew(), TRUE);
105     $this->assertIdentical($config_test->getOriginalId(), $expected['id']);
106     $this->assertIdentical($config_test->id(), $expected['id']);
107     $this->assertTrue($config_test->uuid());
108     $expected['uuid'] = $config_test->uuid();
109     $this->assertIdentical($config_test->label(), $expected['label']);
110
111     // Verify that the entity can be saved.
112     try {
113       $status = $config_test->save();
114       $this->pass('EntityMalformedException was not thrown.');
115     }
116     catch (EntityMalformedException $e) {
117       $this->fail('EntityMalformedException was not thrown.');
118     }
119
120     // The entity path can only be checked after saving.
121     $this->assertIdentical($config_test->url(), Url::fromRoute('entity.config_test.edit_form', ['config_test' => $expected['id']])->toString());
122
123     // Verify that the correct status is returned and properties did not change.
124     $this->assertIdentical($status, SAVED_NEW);
125     $this->assertIdentical($config_test->id(), $expected['id']);
126     $this->assertIdentical($config_test->uuid(), $expected['uuid']);
127     $this->assertIdentical($config_test->label(), $expected['label']);
128     $this->assertIdentical($config_test->isNew(), FALSE);
129     $this->assertIdentical($config_test->getOriginalId(), $expected['id']);
130
131     // Save again, and verify correct status and properties again.
132     $status = $config_test->save();
133     $this->assertIdentical($status, SAVED_UPDATED);
134     $this->assertIdentical($config_test->id(), $expected['id']);
135     $this->assertIdentical($config_test->uuid(), $expected['uuid']);
136     $this->assertIdentical($config_test->label(), $expected['label']);
137     $this->assertIdentical($config_test->isNew(), FALSE);
138     $this->assertIdentical($config_test->getOriginalId(), $expected['id']);
139
140     // Verify that a configuration entity can be saved with an ID of the
141     // maximum allowed length, but not longer.
142
143     // Test with a short ID.
144     $id_length_config_test = entity_create('config_test', [
145       'id' => $this->randomMachineName(8),
146     ]);
147     try {
148       $id_length_config_test->save();
149       $this->pass(SafeMarkup::format("config_test entity with ID length @length was saved.", [
150         '@length' => strlen($id_length_config_test->id())]
151       ));
152     }
153     catch (ConfigEntityIdLengthException $e) {
154       $this->fail($e->getMessage());
155     }
156
157     // Test with an ID of the maximum allowed length.
158     $id_length_config_test = entity_create('config_test', [
159       'id' => $this->randomMachineName(static::MAX_ID_LENGTH),
160     ]);
161     try {
162       $id_length_config_test->save();
163       $this->pass(SafeMarkup::format("config_test entity with ID length @length was saved.", [
164         '@length' => strlen($id_length_config_test->id()),
165       ]));
166     }
167     catch (ConfigEntityIdLengthException $e) {
168       $this->fail($e->getMessage());
169     }
170
171     // Test with an ID exceeding the maximum allowed length.
172     $id_length_config_test = entity_create('config_test', [
173       'id' => $this->randomMachineName(static::MAX_ID_LENGTH + 1),
174     ]);
175     try {
176       $status = $id_length_config_test->save();
177       $this->fail(SafeMarkup::format("config_test entity with ID length @length exceeding the maximum allowed length of @max saved successfully", [
178         '@length' => strlen($id_length_config_test->id()),
179         '@max' => static::MAX_ID_LENGTH,
180       ]));
181     }
182     catch (ConfigEntityIdLengthException $e) {
183       $this->pass(SafeMarkup::format("config_test entity with ID length @length exceeding the maximum allowed length of @max failed to save", [
184         '@length' => strlen($id_length_config_test->id()),
185         '@max' => static::MAX_ID_LENGTH,
186       ]));
187     }
188
189     // Ensure that creating an entity with the same id as an existing one is not
190     // possible.
191     $same_id = entity_create('config_test', [
192       'id' => $config_test->id(),
193     ]);
194     $this->assertIdentical($same_id->isNew(), TRUE);
195     try {
196       $same_id->save();
197       $this->fail('Not possible to overwrite an entity entity.');
198     }
199     catch (EntityStorageException $e) {
200       $this->pass('Not possible to overwrite an entity entity.');
201     }
202
203     // Verify that renaming the ID returns correct status and properties.
204     $ids = [$expected['id'], 'second_' . $this->randomMachineName(4), 'third_' . $this->randomMachineName(4)];
205     for ($i = 1; $i < 3; $i++) {
206       $old_id = $ids[$i - 1];
207       $new_id = $ids[$i];
208       // Before renaming, everything should point to the current ID.
209       $this->assertIdentical($config_test->id(), $old_id);
210       $this->assertIdentical($config_test->getOriginalId(), $old_id);
211
212       // Rename.
213       $config_test->set('id', $new_id);
214       $this->assertIdentical($config_test->id(), $new_id);
215       $status = $config_test->save();
216       $this->assertIdentical($status, SAVED_UPDATED);
217       $this->assertIdentical($config_test->isNew(), FALSE);
218
219       // Verify that originalID points to new ID directly after renaming.
220       $this->assertIdentical($config_test->id(), $new_id);
221       $this->assertIdentical($config_test->getOriginalId(), $new_id);
222     }
223
224     // Test config entity prepopulation.
225     \Drupal::state()->set('config_test.prepopulate', TRUE);
226     $config_test = entity_create('config_test', ['foo' => 'bar']);
227     $this->assertEqual($config_test->get('foo'), 'baz', 'Initial value correctly populated');
228   }
229
230   /**
231    * Tests CRUD operations through the UI.
232    */
233   public function testCRUDUI() {
234     $this->drupalLogin($this->drupalCreateUser(['administer site configuration']));
235
236     $id = strtolower($this->randomMachineName());
237     $label1 = $this->randomMachineName();
238     $label2 = $this->randomMachineName();
239     $label3 = $this->randomMachineName();
240     $message_insert = format_string('%label configuration has been created.', ['%label' => $label1]);
241     $message_update = format_string('%label configuration has been updated.', ['%label' => $label2]);
242     $message_delete = format_string('The test configuration %label has been deleted.', ['%label' => $label2]);
243
244     // Create a configuration entity.
245     $edit = [
246       'id' => $id,
247       'label' => $label1,
248     ];
249     $this->drupalPostForm('admin/structure/config_test/add', $edit, 'Save');
250     $this->assertUrl('admin/structure/config_test');
251     $this->assertResponse(200);
252     $this->assertRaw($message_insert);
253     $this->assertNoRaw($message_update);
254     $this->assertLinkByHref("admin/structure/config_test/manage/$id");
255
256     // Update the configuration entity.
257     $edit = [
258       'label' => $label2,
259     ];
260     $this->drupalPostForm("admin/structure/config_test/manage/$id", $edit, 'Save');
261     $this->assertUrl('admin/structure/config_test');
262     $this->assertResponse(200);
263     $this->assertNoRaw($message_insert);
264     $this->assertRaw($message_update);
265     $this->assertLinkByHref("admin/structure/config_test/manage/$id");
266     $this->assertLinkByHref("admin/structure/config_test/manage/$id/delete");
267
268     // Delete the configuration entity.
269     $this->drupalGet("admin/structure/config_test/manage/$id");
270     $this->clickLink(t('Delete'));
271     $this->assertUrl("admin/structure/config_test/manage/$id/delete");
272     $this->drupalPostForm(NULL, [], 'Delete');
273     $this->assertUrl('admin/structure/config_test');
274     $this->assertResponse(200);
275     $this->assertNoRaw($message_update);
276     $this->assertRaw($message_delete);
277     $this->assertNoText($label1);
278     $this->assertNoLinkByHref("admin/structure/config_test/manage/$id");
279
280     // Re-create a configuration entity.
281     $edit = [
282       'id' => $id,
283       'label' => $label1,
284     ];
285     $this->drupalPostForm('admin/structure/config_test/add', $edit, 'Save');
286     $this->assertUrl('admin/structure/config_test');
287     $this->assertResponse(200);
288     $this->assertText($label1);
289     $this->assertLinkByHref("admin/structure/config_test/manage/$id");
290
291     // Rename the configuration entity's ID/machine name.
292     $edit = [
293       'id' => strtolower($this->randomMachineName()),
294       'label' => $label3,
295     ];
296     $this->drupalPostForm("admin/structure/config_test/manage/$id", $edit, 'Save');
297     $this->assertUrl('admin/structure/config_test');
298     $this->assertResponse(200);
299     $this->assertNoText($label1);
300     $this->assertNoText($label2);
301     $this->assertText($label3);
302     $this->assertNoLinkByHref("admin/structure/config_test/manage/$id");
303     $id = $edit['id'];
304     $this->assertLinkByHref("admin/structure/config_test/manage/$id");
305
306     // Create a configuration entity with '0' machine name.
307     $edit = [
308       'id' => '0',
309       'label' => '0',
310     ];
311     $this->drupalPostForm('admin/structure/config_test/add', $edit, 'Save');
312     $this->assertResponse(200);
313     $message_insert = format_string('%label configuration has been created.', ['%label' => $edit['label']]);
314     $this->assertRaw($message_insert);
315     $this->assertLinkByHref('admin/structure/config_test/manage/0');
316     $this->assertLinkByHref('admin/structure/config_test/manage/0/delete');
317     $this->drupalPostForm('admin/structure/config_test/manage/0/delete', [], 'Delete');
318     $this->assertFalse(entity_load('config_test', '0'), 'Test entity deleted');
319
320     // Create a configuration entity with a property that uses AJAX to show
321     // extra form elements.
322     $this->drupalGet('admin/structure/config_test/add');
323
324     // Test that the dependent element is not shown initially.
325     $this->assertFieldByName('size');
326     $this->assertNoFieldByName('size_value');
327
328     $id = strtolower($this->randomMachineName());
329     $edit = [
330       'id' => $id,
331       'label' => $this->randomString(),
332       'size' => 'custom',
333     ];
334     $this->drupalPostAjaxForm(NULL, $edit, 'size');
335
336     // Check that the dependent element is shown after selecting a 'size' value.
337     $this->assertFieldByName('size');
338     $this->assertFieldByName('size_value');
339
340     // Test the same scenario but it in a non-JS case by using a 'js-hidden'
341     // submit button.
342     $this->drupalGet('admin/structure/config_test/add');
343     $this->assertFieldByName('size');
344     $this->assertNoFieldByName('size_value');
345
346     $this->drupalPostForm(NULL, $edit, 'Change size');
347     $this->assertFieldByName('size');
348     $this->assertFieldByName('size_value');
349
350     // Submit the form with the regular 'Save' button and check that the entity
351     // values are correct.
352     $edit += ['size_value' => 'medium'];
353     $this->drupalPostForm(NULL, $edit, 'Save');
354
355     $entity = entity_load('config_test', $id);
356     $this->assertEqual($entity->get('size'), 'custom');
357     $this->assertEqual($entity->get('size_value'), 'medium');
358   }
359
360 }