media_migration-8.x-1.x-dev/tests/src/Functional/MigrateMediaFromNonMediaSourceTest.php
tests/src/Functional/MigrateMediaFromNonMediaSourceTest.php
<?php
namespace Drupal\Tests\media_migration\Functional;
use Drupal\Tests\media_migration\Traits\MediaMigrationAssertionsForNonMediaSourceTrait;
/**
* Tests migration from a source without enabled media module to media.
*
* @group media_migration
*
* @group legacy
*/
class MigrateMediaFromNonMediaSourceTest extends MigrateMediaTestBase {
use MediaMigrationAssertionsForNonMediaSourceTrait;
/**
* {@inheritdoc}
*/
protected static $modules = [
'linkit',
];
/**
* {@inheritdoc}
*/
protected function getFixtureFilePath() {
return \Drupal::service('extension.list.module')->getPath('media_migration') . '/tests/fixtures/drupal7_nomedia.php';
}
/**
* {@inheritdoc}
*/
protected function getExpectedEntities() {
return [];
}
/**
* Tests the result of the media migration.
*
* @dataProvider providerTestPlainFileToMediaMigration
*/
public function testPlainFileToMediaMigration(bool $classic_node_migration, bool $preexisting_media_types) {
$this->setClassicNodeMigration($classic_node_migration);
// Delete preexisting media types.
$media_types = $this->container->get('entity_type.manager')
->getStorage('media_type')
->loadMultiple();
foreach ($media_types as $media_type) {
$media_type->delete();
}
if ($preexisting_media_types) {
$this->createStandardMediaTypes(TRUE);
}
$this->assertMigrateUpgradeViaUi(FALSE);
$this->assertMediaMigrationResults();
// Check configurations.
$this->assertMediaFieldsAllowedTypes('node', 'article', 'field_image', ['image']);
$this->assertMediaFieldsAllowedTypes('node', 'article', 'field_image_multi', ['image']);
// File fields must allow referencing any kind of existing media.
$media_type_ids = array_keys($this->container->get('entity_type.manager')->getStorage('media_type')->loadMultiple());
$this->assertMediaFieldsAllowedTypes('node', 'article', 'field_file', $media_type_ids);
$this->assertMediaFieldsAllowedTypes('node', 'article', 'field_file_multi', $media_type_ids);
// Check media source field config entities.
$this->assertNonMediaToMediaImageMediaBundleSourceFieldProperties();
$this->assertNonMediaToMediaDocumentMediaBundleSourceFieldProperties();
$this->assertNonMediaToMediaAudioMediaBundleSourceFieldProperties();
$this->assertNonMediaToMediaVideoMediaBundleSourceFieldProperties();
// Check media entities.
$this->assertNonMediaToMedia1FieldValues();
$this->assertNonMediaToMedia2FieldValues();
$this->assertNonMediaToMedia3FieldValues();
$this->assertNonMediaToMedia6FieldValues();
$this->assertNonMediaToMedia7FieldValues();
$this->assertNonMediaToMedia8FieldValues();
$this->assertNonMediaToMedia9FieldValues();
$this->assertNonMediaToMedia10FieldValues();
$this->assertNonMediaToMedia11FieldValues();
$this->assertNonMediaToMedia12FieldValues();
// Check nodes.
$this->assertNonMediaToMediaNode1FieldValues();
$this->assertNonMediaToMediaNode2FieldValues();
}
/**
* Data provider for ::testPlainFileToMediaMigration().
*
* @return array
* The test cases.
*/
public function providerTestPlainFileToMediaMigration() {
$test_cases = [
'Classic node migration, no initial media types' => [
'Classic node migration' => TRUE,
'Preexisting media types' => FALSE,
],
'Complete node migration, no initial media types' => [
'Classic node migration' => FALSE,
'Preexisting media types' => FALSE,
],
'Classic node migration, preexisting media types' => [
'Classic node migration' => TRUE,
'Preexisting media types' => TRUE,
],
'Complete node migration, preexisting media types' => [
'Classic node migration' => FALSE,
'Preexisting media types' => TRUE,
],
];
// Drupal 8.8.x only has 'classic' node migrations.
// @see https://www.drupal.org/node/3105503
if (version_compare(\Drupal::VERSION, '8.9', '<')) {
$test_cases = array_filter($test_cases, function ($test_case) {
return $test_case['Classic node migration'];
});
}
return $test_cases;
}
}
