sqlQueryForm = new SqlQueryForm(new Template());
//$GLOBALS
$GLOBALS['max_upload_size'] = 100;
$GLOBALS['PMA_PHP_SELF'] = Core::getenv('PHP_SELF');
$GLOBALS['db'] = 'PMA_db';
$GLOBALS['table'] = 'PMA_table';
$GLOBALS['text_dir'] = 'text_dir';
$GLOBALS['server'] = 0;
$GLOBALS['cfg']['GZipDump'] = false;
$GLOBALS['cfg']['BZipDump'] = false;
$GLOBALS['cfg']['ZipDump'] = false;
$GLOBALS['cfg']['ServerDefault'] = 'default';
$GLOBALS['cfg']['TextareaAutoSelect'] = true;
$GLOBALS['cfg']['TextareaRows'] = 100;
$GLOBALS['cfg']['TextareaCols'] = 11;
$GLOBALS['cfg']['DefaultTabDatabase'] = 'structure';
$GLOBALS['cfg']['RetainQueryBox'] = true;
$GLOBALS['cfg']['ActionLinksMode'] = 'both';
$GLOBALS['cfg']['DefaultTabTable'] = 'browse';
$GLOBALS['cfg']['CodemirrorEnable'] = true;
$GLOBALS['cfg']['DefaultForeignKeyChecks'] = 'default';
//_SESSION
$_SESSION['relation'][0] = [
'version' => Version::VERSION,
'table_coords' => 'table_name',
'displaywork' => 'displaywork',
'db' => 'information_schema',
'table_info' => 'table_info',
'relwork' => 'relwork',
'relation' => 'relation',
'bookmarkwork' => false,
];
//$GLOBALS
$GLOBALS['cfg']['Server']['user'] = 'user';
$GLOBALS['cfg']['Server']['pmadb'] = 'pmadb';
$GLOBALS['cfg']['Server']['bookmarktable'] = 'bookmarktable';
//$_SESSION
//Mock DBI
$dbi = $this->getMockBuilder(DatabaseInterface::class)
->disableOriginalConstructor()
->getMock();
$fetchResult = [
'index1' => 'table1',
'index2' => 'table2',
];
$dbi->expects($this->any())
->method('fetchResult')
->will($this->returnValue($fetchResult));
$getColumns = [
[
'Field' => 'field1',
'Comment' => 'Comment1',
],
];
$dbi->expects($this->any())
->method('getColumns')
->will($this->returnValue($getColumns));
$GLOBALS['dbi'] = $dbi;
}
/**
* Test for getHtmlForInsert
*/
public function testPMAGetHtmlForSqlQueryFormInsert(): void
{
$GLOBALS['is_upload'] = true;
//Call the test function
$query = 'select * from PMA';
$html = $this->sqlQueryForm->getHtml($query);
//validate 1: query
$this->assertStringContainsString(
htmlspecialchars($query),
$html
);
//validate 2: enable auto select text in textarea
$auto_sel = ' onclick="Functions.selectContent(this, sqlBoxLocked, true);"';
$this->assertStringContainsString(
$auto_sel,
$html
);
//validate 3: MySQLDocumentation::show
$this->assertStringContainsString(
MySQLDocumentation::show('SELECT'),
$html
);
//validate 4: $fields_list
$this->assertStringContainsString(
'assertStringContainsString(
'assertStringContainsString(
'assertStringContainsString(
'assertStringContainsString(
'assertStringContainsString(
'assertStringContainsString(
__('Clear'),
$html
);
}
/**
* Test for getHtml
*/
public function testPMAGetHtmlForSqlQueryForm(): void
{
//Call the test function
$GLOBALS['is_upload'] = true;
$GLOBALS['lang'] = 'ja';
$query = 'select * from PMA';
$html = $this->sqlQueryForm->getHtml($query);
//validate 1: query
$this->assertStringContainsString(
htmlspecialchars($query),
$html
);
//validate 2: $enctype
$enctype = ' enctype="multipart/form-data">';
$this->assertStringContainsString(
$enctype,
$html
);
//validate 3: sqlqueryform
$this->assertStringContainsString(
'id="sqlqueryform" name="sqlform"',
$html
);
//validate 4: $db, $table
$table = $GLOBALS['table'];
$db = $GLOBALS['db'];
$this->assertStringContainsString(
Url::getHiddenInputs($db, $table),
$html
);
//validate 5: $goto
$goto = empty($GLOBALS['goto']) ? Url::getFromRoute('/table/sql') : $GLOBALS['goto'];
$this->assertStringContainsString(
htmlspecialchars($goto),
$html
);
//validate 6: Kanji encoding form
$this->assertStringContainsString(
Encoding::kanjiEncodingForm(),
$html
);
$GLOBALS['lang'] = 'en';
}
}