3 declare(strict_types
=1);
5 namespace PhpMyAdmin\Tests
;
7 use PhpMyAdmin\ConfigStorage\Relation
;
8 use PhpMyAdmin\Current
;
9 use PhpMyAdmin\Dbal\DatabaseInterface
;
10 use PhpMyAdmin\Operations
;
11 use PhpMyAdmin\Table\TableMover
;
12 use PhpMyAdmin\Tests\Stubs\DbiDummy
;
13 use PHPUnit\Framework\Attributes\CoversClass
;
14 use PHPUnit\Framework\Attributes\DataProvider
;
16 use function array_merge
;
18 #[CoversClass(Operations::class)]
19 class OperationsTest
extends AbstractTestCase
21 protected DatabaseInterface
$dbi;
23 protected DbiDummy
$dummyDbi;
25 private Operations
$object;
27 protected function setUp(): void
31 $this->dummyDbi
= $this->createDbiDummy();
32 $this->dbi
= $this->createDatabaseInterface($this->dummyDbi
);
33 DatabaseInterface
::$instance = $this->dbi
;
35 $relation = new Relation($this->dbi
);
36 $this->object = new Operations($this->dbi
, $relation, new TableMover($this->dbi
, $relation));
39 /** @param mixed[] $extraChoice */
40 #[DataProvider('providerGetPartitionMaintenanceChoices')]
41 public function testGetPartitionMaintenanceChoices(string $tableName, array $extraChoice): void
43 Current
::$database = 'database';
44 Current
::$table = $tableName;
47 'ANALYZE' => 'Analyze',
49 'OPTIMIZE' => 'Optimize',
50 'REBUILD' => 'Rebuild',
52 'TRUNCATE' => 'Truncate',
54 $expected = array_merge($choices, $extraChoice);
56 $actual = $this->object->getPartitionMaintenanceChoices();
57 self
::assertSame($expected, $actual);
60 /** @psalm-return array<string, array{0: string, 1: array<string, string>}> */
61 public static function providerGetPartitionMaintenanceChoices(): array
64 'no partition method' => ['no_partition_method', ['COALESCE' => 'Coalesce']],
65 'RANGE partition method' => ['range_partition_method', ['DROP' => 'Drop']],
66 'RANGE COLUMNS partition method' => ['range_columns_partition_method', ['DROP' => 'Drop']],
67 'LIST partition method' => ['list_partition_method', ['DROP' => 'Drop']],
68 'LIST COLUMNS partition method' => ['list_columns_partition_method', ['DROP' => 'Drop']],