public function SqlBaseTest::testMapJoinable in Drupal 9
Same name and namespace in other branches
- 8 core/modules/migrate/tests/src/Unit/SqlBaseTest.php \Drupal\Tests\migrate\Unit\SqlBaseTest::testMapJoinable()
Tests that the ID map is joinable.
@dataProvider sqlBaseTestProvider
Parameters
bool $expected_result: The expected result.
bool $id_map_is_sql: TRUE if we want getIdMap() to return an instance of Sql.
bool $with_id_map: TRUE if we want the ID map to have a valid map of IDs.
array $source_options: (optional) An array of connection options for the source connection. Defaults to an empty array.
array $idmap_options: (optional) An array of connection options for the ID map connection. Defaults to an empty array.
File
- core/
modules/ migrate/ tests/ src/ Unit/ SqlBaseTest.php, line 39 - Contains \Drupal\Tests\migrate\Unit\SqlBaseTest.
Class
- SqlBaseTest
- Tests the SqlBase class.
Namespace
Drupal\Tests\migrate\UnitCode
public function testMapJoinable($expected_result, $id_map_is_sql, $with_id_map, $source_options = [], $idmap_options = []) {
// Setup a connection object.
$source_connection = $this
->getMockBuilder('Drupal\\Core\\Database\\Connection')
->disableOriginalConstructor()
->getMock();
$source_connection
->expects($id_map_is_sql && $with_id_map ? $this
->once() : $this
->never())
->method('getConnectionOptions')
->willReturn($source_options);
// Setup the ID map connection.
$idmap_connection = $this
->getMockBuilder('Drupal\\Core\\Database\\Connection')
->disableOriginalConstructor()
->getMock();
$idmap_connection
->expects($id_map_is_sql && $with_id_map ? $this
->once() : $this
->never())
->method('getConnectionOptions')
->willReturn($idmap_options);
// Setup the Sql object.
$sql = $this
->getMockBuilder('Drupal\\migrate\\Plugin\\migrate\\id_map\\Sql')
->disableOriginalConstructor()
->getMock();
$sql
->expects($id_map_is_sql && $with_id_map ? $this
->once() : $this
->never())
->method('getDatabase')
->willReturn($idmap_connection);
// Setup a migration entity.
$migration = $this
->createMock(MigrationInterface::class);
$migration
->expects($with_id_map ? $this
->once() : $this
->never())
->method('getIdMap')
->willReturn($id_map_is_sql ? $sql : NULL);
// Create our SqlBase test class.
$sql_base = new TestSqlBase();
$sql_base
->setMigration($migration);
$sql_base
->setDatabase($source_connection);
// Configure the idMap to make the check in mapJoinable() pass.
if ($with_id_map) {
$sql_base
->setIds([
'uid' => [
'type' => 'integer',
'alias' => 'u',
],
]);
}
$this
->assertEquals($expected_result, $sql_base
->mapJoinable());
}