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'; } }