MigrationTest.php

Same filename in this branch
  1. 11.x core/modules/migrate/tests/src/Unit/MigrationTest.php
  2. 11.x core/modules/migrate/tests/src/Kernel/MigrationTest.php
Same filename and directory in other branches
  1. 9 core/modules/migrate/tests/src/Unit/MigrationTest.php
  2. 9 core/modules/migrate/tests/src/Kernel/MigrationTest.php
  3. 9 core/modules/migrate/tests/src/Kernel/Plugin/MigrationTest.php
  4. 8.9.x core/modules/migrate/tests/src/Unit/MigrationTest.php
  5. 8.9.x core/modules/migrate/tests/src/Unit/process/MigrationTest.php
  6. 8.9.x core/modules/migrate/tests/src/Kernel/MigrationTest.php
  7. 8.9.x core/modules/migrate/tests/src/Kernel/Plugin/MigrationTest.php
  8. 10 core/modules/migrate/tests/src/Unit/MigrationTest.php
  9. 10 core/modules/migrate/tests/src/Kernel/MigrationTest.php
  10. 10 core/modules/migrate/tests/src/Kernel/Plugin/MigrationTest.php

Namespace

Drupal\Tests\migrate\Kernel\Plugin

File

core/modules/migrate/tests/src/Kernel/Plugin/MigrationTest.php

View source
<?php

declare (strict_types=1);
namespace Drupal\Tests\migrate\Kernel\Plugin;

use Drupal\KernelTests\KernelTestBase;
use Drupal\migrate\MigrateException;
use Drupal\migrate\MigrateSkipRowException;

/**
 * Tests the migration plugin.
 *
 * @coversDefaultClass \Drupal\migrate\Plugin\Migration
 * @group migrate
 */
class MigrationTest extends KernelTestBase {
    
    /**
     * {@inheritdoc}
     */
    protected static $modules = [
        'migrate',
        'migrate_expected_migrations_test',
    ];
    
    /**
     * Tests Migration::getProcessPlugins()
     *
     * @covers ::getProcessPlugins
     */
    public function testGetProcessPlugins() : void {
        $migration = \Drupal::service('plugin.manager.migration')->createStubMigration([]);
        $this->assertEquals([], $migration->getProcessPlugins([]));
    }
    
    /**
     * Tests Migration::getProcessPlugins() throws an exception.
     *
     * @covers ::getProcessPlugins
     */
    public function testGetProcessPluginsException() : void {
        $migration = \Drupal::service('plugin.manager.migration')->createStubMigration([]);
        $this->expectException(MigrateException::class);
        $this->expectExceptionMessage('Invalid process configuration for foobar');
        $migration->getProcessPlugins([
            'foobar' => [
                'plugin' => 'get',
            ],
        ]);
    }
    
    /**
     * Tests Migration::getProcessPlugins()
     *
     * @param array $process
     *   The migration process pipeline.
     *
     * @covers ::getProcessPlugins
     *
     * @dataProvider getProcessPluginsExceptionMessageProvider
     */
    public function testGetProcessPluginsExceptionMessage(array $process) : void {
        // Test with an invalid process pipeline.
        $plugin_definition = [
            'id' => 'foo',
            'process' => $process,
        ];
        $destination = array_key_first($process);
        $migration = \Drupal::service('plugin.manager.migration')->createStubMigration($plugin_definition);
        $this->expectException(MigrateException::class);
        $this->expectExceptionMessage("Invalid process for destination '{$destination}' in migration 'foo'");
        $migration->getProcessPlugins();
    }
    
    /**
     * Provides data for testing invalid process pipeline.
     */
    public static function getProcessPluginsExceptionMessageProvider() : \Generator {
        (yield 'null' => [
            'process' => [
                'dest' => NULL,
            ],
        ]);
        (yield 'boolean' => [
            'process' => [
                'dest' => TRUE,
            ],
        ]);
        (yield 'integer' => [
            'process' => [
                'dest' => 2370,
            ],
        ]);
        (yield 'float' => [
            'process' => [
                'dest' => 1.61,
            ],
        ]);
    }
    
    /**
     * Tests Migration::getMigrationDependencies()
     *
     * @covers ::getMigrationDependencies
     */
    public function testGetMigrationDependencies() : void {
        $plugin_manager = \Drupal::service('plugin.manager.migration');
        $plugin_definition = [
            'id' => 'foo',
            'deriver' => 'fooDeriver',
            'process' => [
                'f1' => 'bar',
                'f2' => [
                    'plugin' => 'migration',
                    'migration' => 'm1',
                ],
                'f3' => [
                    'plugin' => 'sub_process',
                    'process' => [
                        'target_id' => [
                            'plugin' => 'migration',
                            'migration' => 'm2',
                        ],
                    ],
                ],
                'f4' => [
                    'plugin' => 'migration_lookup',
                    'migration' => 'm3',
                ],
                'f5' => [
                    'plugin' => 'sub_process',
                    'process' => [
                        'target_id' => [
                            'plugin' => 'migration_lookup',
                            'migration' => 'm4',
                        ],
                    ],
                ],
                'f6' => [
                    'plugin' => 'iterator',
                    'process' => [
                        'target_id' => [
                            'plugin' => 'migration_lookup',
                            'migration' => 'm5',
                        ],
                    ],
                ],
                'f7' => [
                    'plugin' => 'migration_lookup',
                    'migration' => 'foo',
                ],
            ],
        ];
        $migration = $plugin_manager->createStubMigration($plugin_definition);
        $this->assertSame([
            'required' => [],
            'optional' => [
                'm1',
                'm2',
                'm3',
                'm4',
                'm5',
            ],
        ], $migration->getMigrationDependencies());
    }
    
    /**
     * Tests Migration::getDestinationIds()
     *
     * @covers ::getDestinationIds
     */
    public function testGetDestinationIds() : void {
        $migration = \Drupal::service('plugin.manager.migration')->createStubMigration([
            'destinationIds' => [
                'foo' => 'bar',
            ],
        ]);
        $destination_ids = $migration->getDestinationIds();
        $this->assertNotEmpty($destination_ids, 'Destination ids are not empty');
        $this->assertEquals([
            'foo' => 'bar',
        ], $destination_ids, 'Destination ids match the expected values.');
    }
    
    /**
     * Tests Migration::getDestinationPlugin()
     *
     * @covers ::getDestinationPlugin
     */
    public function testGetDestinationPlugin() : void {
        $migration = \Drupal::service('plugin.manager.migration')->createStubMigration([
            'destination' => [
                'no_stub' => TRUE,
            ],
        ]);
        $this->expectException(MigrateSkipRowException::class);
        $this->expectExceptionMessage("Stub requested but not made because no_stub configuration is set.");
        $migration->getDestinationPlugin(TRUE);
    }

}

Classes

Title Deprecated Summary
MigrationTest Tests the migration plugin.

Buggy or inaccurate documentation? Please file an issue. Need support? Need help programming? Connect with the Drupal community.