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