assertEquals( array( array( array( 0 => 'foo', 'fresh' => false, 'active' => false ), array( 0 => 'bar', 'fresh' => false, 'active' => false ) ) ), $_SESSION['messages'] ); // case 2 unset($_SESSION['messages']); PMA_messagesBegin(); $this->assertEquals( array( 'error' => array(), 'notice' => array() ), $_SESSION['messages'] ); } /** * Test for PMA_messagesSet * * @return void */ public function testPMAmessagesSet() { PMA_messagesSet('type', '123', 'testTitle', 'msg'); $this->assertEquals( array( 'fresh' => true, 'active' => true, 'title' => 'testTitle', 'message' => 'msg' ), $_SESSION['messages']['type']['123'] ); } /** * Test for PMA_messagesEnd * * @return void */ public function testPMAmessagesEnd() { $_SESSION['messages'] = array( array( array('msg' => 'foo', 'active' => false), array('msg' => 'bar', 'active' => true), ) ); PMA_messagesEnd(); $this->assertEquals( array( array( '1' => array( 'msg' => 'bar', 'active' => 1 ) ) ), $_SESSION['messages'] ); } /** * Test for PMA_messagesShowHtml * * @return void */ public function testPMAMessagesShowHTML() { $_SESSION['messages'] = array( 'type' => array( array('title' => 'foo', 'message' => '123', 'fresh' => false), array('title' => 'bar', 'message' => '321', 'fresh' => true), ) ); ob_start(); PMA_messagesShowHtml(); $result = ob_get_clean(); $this->assertContains( '

foo

123
', $result ); $this->assertContains( '

bar

321
', $result ); $this->assertContains( '", $result ); } /** * Test for PMA_checkConfigRw * * @return void */ public function testPMACheckConfigRw() { if (! PMA_HAS_RUNKIT) { $this->markTestSkipped('Cannot redefine constant'); } $redefine = null; $GLOBALS['cfg']['AvailableCharsets'] = array(); $GLOBALS['server'] = 0; $GLOBALS['ConfigFile'] = new ConfigFile(); if (!defined('SETUP_CONFIG_FILE')) { define('SETUP_CONFIG_FILE', 'test/test_data/configfile'); } else { $redefine = 'SETUP_CONFIG_FILE'; runkit_constant_redefine( 'SETUP_CONFIG_FILE', 'test/test_data/configfile' ); } $is_readable = false; $is_writable = false; $file_exists = false; PMA_checkConfigRw($is_readable, $is_writable, $file_exists); $this->assertTrue( $is_readable ); $this->assertTrue( $is_writable ); $this->assertFalse( $file_exists ); runkit_constant_redefine( 'SETUP_CONFIG_FILE', 'test/test_data/test.file' ); PMA_checkConfigRw($is_readable, $is_writable, $file_exists); $this->assertTrue( $is_readable ); $this->assertTrue( $is_writable ); $this->assertTrue( $file_exists ); if ($redefine !== null) { runkit_constant_redefine('SETUP_CONFIG_FILE', $redefine); } else { runkit_constant_remove('SETUP_CONFIG_FILE'); } } /** * Test for ServerConfigChecks::performConfigChecks * * @return void * @group medium */ public function testServerConfigChecksPerformConfigChecks() { $GLOBALS['cfg']['AvailableCharsets'] = array(); $GLOBALS['cfg']['ServerDefault'] = 0; $GLOBALS['server'] = 0; $cf = new ConfigFile(); $GLOBALS['ConfigFile'] = $cf; $reflection = new \ReflectionProperty('PMA\libraries\config\ConfigFile', '_id'); $reflection->setAccessible(true); $sessionID = $reflection->getValue($cf); $_SESSION[$sessionID]['Servers'] = array( '1' => array( 'host' => 'localhost', 'ssl' => false, 'extension' => 'mysql', 'auth_type' => 'config', 'user' => 'username', 'password' => 'password', 'AllowRoot' => true, 'AllowNoPassword' => true, ) ); $_SESSION[$sessionID]['AllowArbitraryServer'] = true; $_SESSION[$sessionID]['LoginCookieValidity'] = 5000; $_SESSION[$sessionID]['LoginCookieStore'] = 4000; $_SESSION[$sessionID]['SaveDir'] = true; $_SESSION[$sessionID]['TempDir'] = true; $_SESSION[$sessionID]['GZipDump'] = true; $_SESSION[$sessionID]['BZipDump'] = true; $_SESSION[$sessionID]['ZipDump'] = true; $noticeArrayKeys = array( 'TempDir', 'SaveDir', 'LoginCookieValidity', 'AllowArbitraryServer', 'Servers/1/AllowNoPassword', 'Servers/1/auth_type', 'Servers/1/ssl' ); $errorArrayKeys = array( 'LoginCookieValidity' ); if (@!function_exists('gzopen') || @!function_exists('gzencode')) { $errorArrayKeys[] = 'GZipDump'; } if (@!function_exists('bzopen') || @!function_exists('bzcompress')) { $errorArrayKeys[] = 'BZipDump'; } if (!@function_exists('zip_open')) { $errorArrayKeys[] = 'ZipDump_import'; } if (!@function_exists('gzcompress')) { $errorArrayKeys[] = 'ZipDump_export'; } $configChecker = new ServerConfigChecks($GLOBALS['ConfigFile']); $configChecker->performConfigChecks(); foreach ($noticeArrayKeys as $noticeKey) { $this->assertArrayHasKey( $noticeKey, $_SESSION['messages']['notice'] ); } foreach ($errorArrayKeys as $errorKey) { $this->assertArrayHasKey( $errorKey, $_SESSION['messages']['error'] ); } // Case 2 unset($_SESSION['messages']); unset($_SESSION[$sessionID]); $_SESSION[$sessionID]['Servers'] = array( '1' => array( 'host' => 'localhost', 'ssl' => true, 'extension' => 'mysqli', 'auth_type' => 'cookie', 'AllowRoot' => false ) ); $_SESSION[$sessionID]['AllowArbitraryServer'] = false; $_SESSION[$sessionID]['LoginCookieValidity'] = -1; $_SESSION[$sessionID]['LoginCookieStore'] = 0; $_SESSION[$sessionID]['SaveDir'] = ''; $_SESSION[$sessionID]['TempDir'] = ''; $_SESSION[$sessionID]['GZipDump'] = false; $_SESSION[$sessionID]['BZipDump'] = false; $_SESSION[$sessionID]['ZipDump'] = false; $configChecker = new ServerConfigChecks($GLOBALS['ConfigFile']); $configChecker->performConfigChecks(); $this->assertArrayHasKey( 'blowfish_secret_created', $_SESSION['messages']['notice'] ); foreach ($noticeArrayKeys as $noticeKey) { $this->assertArrayNotHasKey( $noticeKey, $_SESSION['messages']['notice'] ); } $this->assertArrayNotHasKey( 'error', $_SESSION['messages'] ); // Case 3 $_SESSION[$sessionID]['blowfish_secret'] = 'sec'; $_SESSION[$sessionID]['Servers'] = array( '1' => array( 'host' => 'localhost', 'auth_type' => 'cookie' ) ); $configChecker = new ServerConfigChecks($GLOBALS['ConfigFile']); $configChecker->performConfigChecks(); $this->assertArrayHasKey( 'blowfish_warnings2', $_SESSION['messages']['error'] ); } }