1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68
|
<?php
declare(strict_types=1);
namespace PhpMyAdmin\Tests;
use PhpMyAdmin\ConfigStorage\Relation;
use PhpMyAdmin\Operations;
use function array_merge;
/**
* @covers \PhpMyAdmin\Operations
*/
#[\PHPUnit\Framework\Attributes\CoversClass(\PhpMyAdmin\Operations::class)]
class OperationsTest extends AbstractTestCase
{
/** @var Operations */
private $object;
protected function setUp(): void
{
parent::setUp();
$GLOBALS['server'] = 1;
$this->object = new Operations($this->dbi, new Relation($this->dbi));
}
/**
* @dataProvider providerGetPartitionMaintenanceChoices
*/
#[\PHPUnit\Framework\Attributes\DataProvider('providerGetPartitionMaintenanceChoices')]
public function testGetPartitionMaintenanceChoices(string $tableName, array $extraChoice): void
{
global $db, $table;
$db = 'database';
$table = $tableName;
$choices = [
'ANALYZE' => 'Analyze',
'CHECK' => 'Check',
'OPTIMIZE' => 'Optimize',
'REBUILD' => 'Rebuild',
'REPAIR' => 'Repair',
'TRUNCATE' => 'Truncate',
];
$expected = array_merge($choices, $extraChoice);
$actual = $this->object->getPartitionMaintenanceChoices();
self::assertSame($expected, $actual);
}
/**
* @psalm-return array<string, array{0: string, 1: array<string, string>}>
*/
public static function providerGetPartitionMaintenanceChoices(): array
{
return [
'no partition method' => ['no_partition_method', ['COALESCE' => 'Coalesce']],
'RANGE partition method' => ['range_partition_method', ['DROP' => 'Drop']],
'RANGE COLUMNS partition method' => ['range_columns_partition_method', ['DROP' => 'Drop']],
'LIST partition method' => ['list_partition_method', ['DROP' => 'Drop']],
'LIST COLUMNS partition method' => ['list_columns_partition_method', ['DROP' => 'Drop']],
];
}
}
|