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. 11.x 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 Deprecated Modifiers Object type Summary Overrides
MigrationConfigurationTraitTest::providerTestGetLegacyDrupalVersion public static function Provides data for testGetLegacyDrupalVersion.
MigrationConfigurationTraitTest::testGetLegacyDrupalVersion public function @covers ::getLegacyDrupalVersion[[api-linebreak]]
@dataProvider providerTestGetLegacyDrupalVersion
PhpUnitWarnings::$deprecationWarnings private static property Deprecation warnings from PHPUnit to raise with @trigger_error().
PhpUnitWarnings::addWarning public function Converts PHPUnit deprecation warnings to E_USER_DEPRECATED.
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.
RandomGeneratorTrait::randomStringValidate Deprecated public function Callback for random string validation.
UnitTestCase::$root protected property The app root. 1
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 358
UnitTestCase::setUpBeforeClass public static function
UnitTestCase::__get public function

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