annotate core/modules/media/tests/src/FunctionalJavascript/MediaSourceTestBase.php @ 2:92f882872392

Trusted hosts, + remove migration modules
author Chris Cannam
date Tue, 05 Dec 2017 09:26:43 +0000
parents 4c8ae668cc8c
children af1871eacc83
rev   line source
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 }