View source
<?php
declare (strict_types=1);
namespace Drupal\Tests\migrate\Kernel;
use Drupal\Core\Database\Query\ConditionInterface;
use Drupal\Core\Database\Query\SelectInterface;
use Drupal\Core\Database\StatementInterface;
use Drupal\migrate\Exception\RequirementsException;
use Drupal\Core\Database\Database;
use Drupal\migrate\Plugin\migrate\source\SqlBase;
use Drupal\migrate\Plugin\MigrationInterface;
class SqlBaseTest extends MigrateTestBase {
protected $migration;
protected function setUp() : void {
parent::setUp();
$this->migration = $this
->createMock(MigrationInterface::class);
$this->migration
->method('id')
->willReturn('foo');
}
public function testConnectionTypes() {
$sql_base = new TestSqlBase([], $this->migration);
$this
->assertSame('default', $sql_base
->getDatabase()
->getTarget());
$this
->assertSame('migrate', $sql_base
->getDatabase()
->getKey());
$target = 'test_fallback_target';
$key = 'test_fallback_key';
$config = [
'target' => $target,
'key' => $key,
];
$database_state_key = 'test_fallback_state';
\Drupal::state()
->set($database_state_key, $config);
\Drupal::state()
->set('migrate.fallback_state_key', $database_state_key);
Database::addConnectionInfo($key, $target, Database::getConnectionInfo('default')['default']);
$this
->assertSame($sql_base
->getDatabase()
->getTarget(), $target);
$this
->assertSame($sql_base
->getDatabase()
->getKey(), $key);
$target = 'test_db_target';
$key = 'test_migrate_connection';
$config = [
'target' => $target,
'key' => $key,
];
$sql_base
->setConfiguration($config);
Database::addConnectionInfo($key, $target, Database::getConnectionInfo('default')['default']);
$this
->assertSame($sql_base
->getDatabase()
->getTarget(), $target);
$this
->assertSame($sql_base
->getDatabase()
->getKey(), $key);
$sql_base = new TestSqlBase([], $this->migration);
$target = 'test_db_target2';
$key = 'test_migrate_connection2';
$database = Database::getConnectionInfo('default')['default'];
$config = [
'target' => $target,
'key' => $key,
'database' => $database,
];
$sql_base
->setConfiguration($config);
$sql_base
->getDatabase();
$this
->assertSame(Database::getConnectionInfo($key)[$target], $database);
$target = 'test_state_db_target';
$key = 'test_state_migrate_connection';
$config = [
'target' => $target,
'key' => $key,
];
$database_state_key = 'migrate_sql_base_test';
\Drupal::state()
->set($database_state_key, $config);
$sql_base
->setConfiguration([
'database_state_key' => $database_state_key,
]);
Database::addConnectionInfo($key, $target, Database::getConnectionInfo('default')['default']);
$this
->assertSame($sql_base
->getDatabase()
->getTarget(), $target);
$this
->assertSame($sql_base
->getDatabase()
->getKey(), $key);
$sql_base = new TestSqlBase([], $this->migration);
$target = 'test_state_db_target2';
$key = 'test_state_migrate_connection2';
$database = Database::getConnectionInfo('default')['default'];
$config = [
'target' => $target,
'key' => $key,
'database' => $database,
];
$database_state_key = 'migrate_sql_base_test2';
\Drupal::state()
->set($database_state_key, $config);
$sql_base
->setConfiguration([
'database_state_key' => $database_state_key,
]);
$sql_base
->getDatabase();
$this
->assertSame(Database::getConnectionInfo($key)[$target], $database);
\Drupal::state()
->delete('migrate.fallback_state_key');
$sql_base
->setConfiguration([]);
Database::renameConnection('migrate', 'fallback_connection');
$this
->expectException(RequirementsException::class);
$this
->expectExceptionMessage('No database connection configured for source plugin');
$sql_base
->getDatabase();
}
public function testBrokenConnection() : void {
if (Database::getConnection()
->driver() === 'sqlite') {
$this
->markTestSkipped('Not compatible with sqlite');
}
$sql_base = new TestSqlBase([], $this->migration);
$target = 'test_state_db_target2';
$key = 'test_state_migrate_connection2';
$database = Database::getConnectionInfo('default')['default'];
$database['database'] = 'godot';
$config = [
'target' => $target,
'key' => $key,
'database' => $database,
];
$database_state_key = 'migrate_sql_base_test2';
\Drupal::state()
->set($database_state_key, $config);
$sql_base
->setConfiguration([
'database_state_key' => $database_state_key,
]);
$this
->expectException(RequirementsException::class);
$this
->expectExceptionMessage('No database connection available for source plugin sql_base');
$sql_base
->checkRequirements();
}
public function testHighWater($high_water = NULL, array $query_result = []) {
$configuration = [
'high_water_property' => [
'name' => 'order',
],
];
$source = new TestSqlBase($configuration, $this->migration);
if ($high_water) {
\Drupal::keyValue('migrate:high_water')
->set($this->migration
->id(), $high_water);
}
$statement = $this
->createMock(StatementInterface::class);
$statement
->expects($this
->atLeastOnce())
->method('setFetchMode')
->with(\PDO::FETCH_ASSOC);
$query = $this
->createMock(SelectInterface::class);
$query
->method('execute')
->willReturn($statement);
$query
->expects($this
->atLeastOnce())
->method('orderBy')
->with('order', 'ASC');
$condition_group = $this
->createMock(ConditionInterface::class);
$query
->method('orConditionGroup')
->willReturn($condition_group);
$source
->setQuery($query);
$source
->rewind();
}
public static function highWaterDataProvider() {
return [
'no high-water value set' => [],
'high-water value set' => [
33,
],
];
}
}
class TestSqlBase extends SqlBase {
protected $query;
public function __construct(array $configuration = [], MigrationInterface $migration = NULL) {
parent::__construct($configuration, 'sql_base', [
'requirements_met' => TRUE,
], $migration, \Drupal::state());
}
public function getDatabase() {
$this->database = NULL;
return parent::getDatabase();
}
public function setConfiguration($config) {
$this->configuration = $config;
}
public function getIds() {
return [];
}
public function fields() {
throw new \RuntimeException(__METHOD__ . " not implemented for " . __CLASS__);
}
public function query() {
return $this->query;
}
public function setQuery(SelectInterface $query) {
$this->query = $query;
}
}