Chris@0
|
1 <?php
|
Chris@0
|
2
|
Chris@0
|
3 namespace Drupal\Tests\media\FunctionalJavascript;
|
Chris@0
|
4
|
Chris@0
|
5 use Drupal\field\Entity\FieldConfig;
|
Chris@0
|
6 use Drupal\field\Entity\FieldStorageConfig;
|
Chris@0
|
7 use Drupal\media\Entity\MediaType;
|
Chris@0
|
8
|
Chris@0
|
9 /**
|
Chris@0
|
10 * Base class for media source tests.
|
Chris@0
|
11 */
|
Chris@0
|
12 abstract class MediaSourceTestBase extends MediaJavascriptTestBase {
|
Chris@0
|
13
|
Chris@0
|
14 /**
|
Chris@0
|
15 * Creates storage and field instance, attached to a given media type.
|
Chris@0
|
16 *
|
Chris@0
|
17 * @param string $field_name
|
Chris@0
|
18 * The field name.
|
Chris@0
|
19 * @param string $field_type
|
Chris@0
|
20 * The field type.
|
Chris@0
|
21 * @param string $media_type_id
|
Chris@0
|
22 * The media type config entity ID.
|
Chris@0
|
23 */
|
Chris@0
|
24 protected function createMediaTypeField($field_name, $field_type, $media_type_id) {
|
Chris@0
|
25 $storage = FieldStorageConfig::create([
|
Chris@0
|
26 'field_name' => $field_name,
|
Chris@0
|
27 'entity_type' => 'media',
|
Chris@0
|
28 'type' => $field_type,
|
Chris@0
|
29 ]);
|
Chris@0
|
30 $storage->save();
|
Chris@0
|
31
|
Chris@0
|
32 FieldConfig::create([
|
Chris@0
|
33 'field_storage' => $storage,
|
Chris@0
|
34 'bundle' => $media_type_id,
|
Chris@0
|
35 ])->save();
|
Chris@0
|
36
|
Chris@0
|
37 // Make the field widget visible in the form display.
|
Chris@0
|
38 $component = \Drupal::service('plugin.manager.field.widget')
|
Chris@0
|
39 ->prepareConfiguration($field_type, []);
|
Chris@0
|
40
|
Chris@0
|
41 // @todo Replace entity_get_form_display() when #2367933 is done.
|
Chris@0
|
42 // https://www.drupal.org/node/2872159.
|
Chris@0
|
43 $entity_form_display = entity_get_form_display('media', $media_type_id, 'default');
|
Chris@0
|
44 $entity_form_display->setComponent($field_name, $component)
|
Chris@0
|
45 ->save();
|
Chris@0
|
46
|
Chris@0
|
47 // Use the default formatter and settings.
|
Chris@0
|
48 $component = \Drupal::service('plugin.manager.field.formatter')
|
Chris@0
|
49 ->prepareConfiguration($field_type, []);
|
Chris@0
|
50
|
Chris@0
|
51 // @todo Replace entity_get_display() when #2367933 is done.
|
Chris@0
|
52 // https://www.drupal.org/node/2872159.
|
Chris@0
|
53 $entity_display = entity_get_display('media', $media_type_id, 'default');
|
Chris@0
|
54 $entity_display->setComponent($field_name, $component)
|
Chris@0
|
55 ->save();
|
Chris@0
|
56 }
|
Chris@0
|
57
|
Chris@0
|
58 /**
|
Chris@0
|
59 * Create a set of fields in a media type.
|
Chris@0
|
60 *
|
Chris@0
|
61 * @param array $fields
|
Chris@0
|
62 * An associative array where keys are field names and values field types.
|
Chris@0
|
63 * @param string $media_type_id
|
Chris@0
|
64 * The media type config entity ID.
|
Chris@0
|
65 */
|
Chris@0
|
66 protected function createMediaTypeFields(array $fields, $media_type_id) {
|
Chris@0
|
67 foreach ($fields as $field_name => $field_type) {
|
Chris@0
|
68 $this->createMediaTypeField($field_name, $field_type, $media_type_id);
|
Chris@0
|
69 }
|
Chris@0
|
70 }
|
Chris@0
|
71
|
Chris@0
|
72 /**
|
Chris@0
|
73 * Hides a widget in the default form display config.
|
Chris@0
|
74 *
|
Chris@0
|
75 * @param string $field_name
|
Chris@0
|
76 * The field name.
|
Chris@0
|
77 * @param string $media_type_id
|
Chris@0
|
78 * The media type config entity ID.
|
Chris@0
|
79 */
|
Chris@0
|
80 protected function hideMediaTypeFieldWidget($field_name, $media_type_id) {
|
Chris@0
|
81 /** @var \Drupal\Core\Entity\Display\EntityFormDisplayInterface $entity_form_display */
|
Chris@0
|
82 $entity_form_display = entity_get_form_display('media', $media_type_id, 'default');
|
Chris@0
|
83 if ($entity_form_display->getComponent($field_name)) {
|
Chris@0
|
84 $entity_form_display->removeComponent($field_name)->save();
|
Chris@0
|
85 }
|
Chris@0
|
86 }
|
Chris@0
|
87
|
Chris@0
|
88 /**
|
Chris@0
|
89 * Test generic media type creation.
|
Chris@0
|
90 *
|
Chris@0
|
91 * @param string $media_type_id
|
Chris@0
|
92 * The media type config entity ID.
|
Chris@0
|
93 * @param string $source_id
|
Chris@0
|
94 * The media source ID.
|
Chris@0
|
95 * @param array $provided_fields
|
Chris@0
|
96 * (optional) An array of field machine names this type provides.
|
Chris@0
|
97 *
|
Chris@0
|
98 * @return \Drupal\media\MediaTypeInterface
|
Chris@0
|
99 * The created media type.
|
Chris@0
|
100 */
|
Chris@0
|
101 public function doTestCreateMediaType($media_type_id, $source_id, array $provided_fields = []) {
|
Chris@0
|
102 $session = $this->getSession();
|
Chris@0
|
103 $page = $session->getPage();
|
Chris@0
|
104 $assert_session = $this->assertSession();
|
Chris@0
|
105
|
Chris@0
|
106 $this->drupalGet('admin/structure/media/add');
|
Chris@0
|
107 $page->fillField('label', $media_type_id);
|
Chris@0
|
108 $this->getSession()
|
Chris@0
|
109 ->wait(5000, "jQuery('.machine-name-value').text() === '{$media_type_id}'");
|
Chris@0
|
110
|
Chris@0
|
111 // Make sure the source is available.
|
Chris@0
|
112 $assert_session->fieldExists('Media source');
|
Chris@0
|
113 $assert_session->optionExists('Media source', $source_id);
|
Chris@0
|
114 $page->selectFieldOption('Media source', $source_id);
|
Chris@0
|
115 $result = $assert_session->waitForElementVisible('css', 'fieldset[data-drupal-selector="edit-source-configuration"]');
|
Chris@0
|
116 $this->assertNotEmpty($result);
|
Chris@0
|
117
|
Chris@0
|
118 // Make sure the provided fields are visible on the form.
|
Chris@0
|
119 foreach ($provided_fields as $provided_field) {
|
Chris@0
|
120 $result = $assert_session->waitForElementVisible('css', 'select[name="field_map[' . $provided_field . ']"]');
|
Chris@0
|
121 $this->assertNotEmpty($result);
|
Chris@0
|
122 }
|
Chris@0
|
123
|
Chris@0
|
124 // Save the form to create the type.
|
Chris@0
|
125 $page->pressButton('Save');
|
Chris@0
|
126 $assert_session->pageTextContains('The media type ' . $media_type_id . ' has been added.');
|
Chris@0
|
127 $this->drupalGet('admin/structure/media');
|
Chris@0
|
128 $assert_session->pageTextContains($media_type_id);
|
Chris@0
|
129
|
Chris@0
|
130 // Bundle definitions are statically cached in the context of the test, we
|
Chris@0
|
131 // need to make sure we have updated information before proceeding with the
|
Chris@0
|
132 // actions on the UI.
|
Chris@0
|
133 \Drupal::service('entity_type.bundle.info')->clearCachedBundles();
|
Chris@0
|
134
|
Chris@0
|
135 return MediaType::load($media_type_id);
|
Chris@0
|
136 }
|
Chris@0
|
137
|
Chris@0
|
138 }
|