class MigrationConfigurationTraitTest

Same name and namespace in other branches
  1. 9 core/modules/migrate_drupal/tests/src/Unit/MigrationConfigurationTraitTest.php \Drupal\Tests\migrate_drupal\Unit\MigrationConfigurationTraitTest
  2. 10 core/modules/migrate_drupal/tests/src/Unit/MigrationConfigurationTraitTest.php \Drupal\Tests\migrate_drupal\Unit\MigrationConfigurationTraitTest

@coversDefaultClass \Drupal\migrate_drupal\MigrationConfigurationTrait @group migrate_drupal

Hierarchy

Expanded class hierarchy of MigrationConfigurationTraitTest

File

core/modules/migrate_drupal/tests/src/Unit/MigrationConfigurationTraitTest.php, line 15

Namespace

Drupal\Tests\migrate_drupal\Unit
View source
class MigrationConfigurationTraitTest extends UnitTestCase {
    
    /**
     * @covers ::getLegacyDrupalVersion
     * @dataProvider providerTestGetLegacyDrupalVersion
     */
    public function testGetLegacyDrupalVersion($expected_version_string, $schema_version, $exception, $system_table_exists) : void {
        if ($schema_version) {
            $statement = $this->createMock('\\Drupal\\Core\\Database\\StatementInterface');
            $statement->expects($this->any())
                ->method('fetchField')
                ->willReturn($schema_version);
        }
        $schema = $this->createMock('\\Drupal\\Core\\Database\\Schema');
        $schema->expects($this->once())
            ->method('tableExists')
            ->willReturn($system_table_exists);
        $connection = $this->getMockBuilder('Drupal\\Core\\Database\\Connection')
            ->disableOriginalConstructor()
            ->getMock();
        if ($exception) {
            $connection->expects($this->any())
                ->method('query')
                ->willThrowException($exception);
        }
        else {
            $connection->expects($this->any())
                ->method('query')
                ->willReturn($statement);
        }
        $connection->expects($this->any())
            ->method('schema')
            ->willReturn($schema);
        $actual_version_string = TestMigrationConfigurationTrait::getLegacyDrupalVersion($connection);
        $this->assertSame($expected_version_string, $actual_version_string);
    }
    
    /**
     * Provides data for testGetLegacyDrupalVersion.
     */
    public static function providerTestGetLegacyDrupalVersion() {
        return [
            'D5' => [
                'expected_version_string' => '5',
                'schema_version' => '1678',
                'exception' => NULL,
                'system_table_exists' => TRUE,
            ],
            'D6' => [
                'expected_version_string' => '6',
                'schema_version' => '6057',
                'exception' => NULL,
                'system_table_exists' => TRUE,
            ],
            'D7' => [
                'expected_version_string' => '7',
                'schema_version' => '7065',
                'exception' => NULL,
                'system_table_exists' => TRUE,
            ],
            'D8' => [
                'expected_version_string' => FALSE,
                'schema_version' => serialize('8976'),
                'exception' => NULL,
                'system_table_exists' => FALSE,
            ],
            'D9' => [
                'expected_version_string' => FALSE,
                'schema_version' => serialize('9270'),
                'exception' => NULL,
                'system_table_exists' => FALSE,
            ],
            'D10' => [
                'expected_version_string' => FALSE,
                'schema_version' => serialize('10101'),
                'exception' => NULL,
                'system_table_exists' => FALSE,
            ],
            'Not drupal' => [
                'expected_version_string' => FALSE,
                'schema_version' => "not drupal I guess",
                'exception' => NULL,
                'system_table_exists' => FALSE,
            ],
            'D5 almost' => [
                'expected_version_string' => FALSE,
                'schema_version' => '123',
                'exception' => NULL,
                'system_table_exists' => TRUE,
            ],
            'D5/6/7 Exception' => [
                'expected_version_string' => FALSE,
                'schema_version' => NULL,
                'exception' => new DatabaseExceptionWrapper(),
                'system_table_exists' => TRUE,
            ],
            'D8/9 Exception' => [
                'expected_version_string' => FALSE,
                'schema_version' => NULL,
                'exception' => new DatabaseExceptionWrapper(),
                'system_table_exists' => FALSE,
            ],
        ];
    }

}

Members

Title Sort descending Modifiers Object type Summary Overrides
ExpectDeprecationTrait::expectDeprecation public function Adds an expected deprecation.
ExpectDeprecationTrait::getCallableName private static function Returns a callable as a string suitable for inclusion in a message.
ExpectDeprecationTrait::setUpErrorHandler public function Sets up the test error handler.
ExpectDeprecationTrait::tearDownErrorHandler public function Tears down the test error handler.
MigrationConfigurationTraitTest::providerTestGetLegacyDrupalVersion public static function Provides data for testGetLegacyDrupalVersion.
MigrationConfigurationTraitTest::testGetLegacyDrupalVersion public function @covers ::getLegacyDrupalVersion
@dataProvider providerTestGetLegacyDrupalVersion
RandomGeneratorTrait::getRandomGenerator protected function Gets the random generator for the utility methods.
RandomGeneratorTrait::randomMachineName protected function Generates a unique random string containing letters and numbers.
RandomGeneratorTrait::randomObject public function Generates a random PHP object.
RandomGeneratorTrait::randomString public function Generates a pseudo-random string of ASCII characters of codes 32 to 126.
UnitTestCase::$root protected property The app root.
UnitTestCase::getClassResolverStub protected function Returns a stub class resolver.
UnitTestCase::getConfigFactoryStub public function Returns a stub config factory that behaves according to the passed array.
UnitTestCase::getConfigStorageStub public function Returns a stub config storage that returns the supplied configuration.
UnitTestCase::getContainerWithCacheTagsInvalidator protected function Sets up a container with a cache tags invalidator.
UnitTestCase::getStringTranslationStub public function Returns a stub translation manager that just returns the passed string.
UnitTestCase::setUp protected function 354
UnitTestCase::setUpBeforeClass public static function

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