dbQuery( 'USE `' . $this->databaseName . '`;' . 'CREATE TABLE `test_table` (' . ' `id` int(11) NOT NULL AUTO_INCREMENT,' . ' `val` int(11) NOT NULL,' . ' PRIMARY KEY (`id`)' . ');' . 'INSERT INTO `test_table` (val) VALUES (2);' ); $this->login(); } /** * Test for server level export * * @param string $plugin Export format * @param array $expected Array of expected strings * * @dataProvider exportDataProvider * @group large */ public function testServerExport(string $plugin, array $expected): void { $text = $this->doExport('server', $plugin); foreach ($expected as $str) { $this->assertStringContainsString($str, $text); } } /** * Test for db level export * * @param string $plugin Export format * @param array $expected Array of expected strings * * @dataProvider exportDataProvider * @group large */ public function testDbExport(string $plugin, array $expected): void { $this->navigateDatabase($this->databaseName); $text = $this->doExport('db', $plugin); foreach ($expected as $str) { $this->assertStringContainsString($str, $text); } } /** * Test for table level export * * @param string $plugin Export format * @param array $expected Array of expected strings * * @dataProvider exportDataProvider * @group large */ public function testTableExport(string $plugin, array $expected): void { $this->dbQuery('INSERT INTO `' . $this->databaseName . '`.`test_table` (val) VALUES (3);'); $this->navigateTable('test_table'); $text = $this->doExport('table', $plugin); foreach ($expected as $str) { $this->assertStringContainsString($str, $text); } } /** * Data provider for testServerExport */ public function exportDataProvider(): array { return [ [ 'CSV', ['"1","2"'], ], [ 'SQL', [ 'CREATE TABLE IF NOT EXISTS `test_table`', 'INSERT INTO `test_table` (`id`, `val`) VALUES', '(1, 2)', ], ], [ 'JSON', ['{"id":"1","val":"2"}'], ], ]; } /** * Function that goes to the import page, uploads a file and submit form * * @param string $type level: server, db or import * @param string $plugin format: csv, json, etc * * @return string export string */ private function doExport(string $type, string $plugin): string { $this->expandMore(); $this->waitForElement('partialLinkText', 'Export')->click(); $this->waitAjax(); $this->waitForElement('id', 'quick_or_custom'); $this->byCssSelector('label[for=radio_custom_export]')->click(); $this->selectByLabel( $this->byId('plugins'), $plugin ); if ($type === 'server') { $this->scrollIntoView('databases_and_tables', 200); sleep(1); $this->scrollIntoView('databases_and_tables', 200); $this->byPartialLinkText('Unselect all')->click(); $this->byCssSelector('option[value="' . $this->databaseName . '"]')->click(); } if ($type === 'table') { $this->scrollIntoView('radio_allrows_0'); $this->byCssSelector('label[for=radio_allrows_0]')->click(); $this->byName('limit_to')->clear(); $this->byName('limit_to')->sendKeys('1'); } $this->scrollIntoView('radio_view_as_text'); sleep(1); $this->scrollIntoView('radio_view_as_text'); $this->byCssSelector('label[for=radio_view_as_text]')->click(); if ($plugin === 'SQL') { if ($type !== 'db') { $this->scrollIntoView('radio_sql_structure_or_data_structure_and_data'); sleep(1); $this->scrollIntoView('radio_sql_structure_or_data_structure_and_data'); $this->byCssSelector('label[for=radio_sql_structure_or_data_structure_and_data]')->click(); } $this->scrollIntoView('checkbox_sql_if_not_exists'); sleep(1); $this->scrollIntoView('checkbox_sql_if_not_exists'); $ele = $this->byId('checkbox_sql_if_not_exists'); if (! $ele->isSelected()) { $this->byCssSelector('label[for=checkbox_sql_if_not_exists]')->click(); } } $this->scrollToBottom(); sleep(1); $this->scrollToBottom(); $this->byId('buttonGo')->click(); $this->waitAjax(); sleep(1); return $this->waitForElement('id', 'textSQLDUMP')->getText(); } }