694 lines
		
	
	
		
			19 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
			
		
		
	
	
			694 lines
		
	
	
		
			19 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
| <?php
 | |
| /* vim: set expandtab sw=4 ts=4 sts=4: */
 | |
| /**
 | |
|  * Test for Message class
 | |
|  *
 | |
|  * @package PhpMyAdmin-test
 | |
|  */
 | |
| 
 | |
| /*
 | |
|  * Include to test.
 | |
|  */
 | |
| use PMA\libraries\Theme;
 | |
| 
 | |
| require_once 'libraries/sanitizing.lib.php';
 | |
| require_once 'test/PMATestCase.php';
 | |
| 
 | |
| /**
 | |
|  * Test for Message class
 | |
|  *
 | |
|  * @package PhpMyAdmin-test
 | |
|  */
 | |
| class MessageTest extends PMATestCase
 | |
| {
 | |
|     /**
 | |
|      * @var    PMA\libraries\Message
 | |
|      * @access protected
 | |
|      */
 | |
|     protected $object;
 | |
| 
 | |
|     /**
 | |
|      * Sets up the fixture, for example, opens a network connection.
 | |
|      * This method is called before a test is executed.
 | |
|      *
 | |
|      * @access protected
 | |
|      * @return void
 | |
|      */
 | |
|     protected function setUp()
 | |
|     {
 | |
|         $this->object = new PMA\libraries\Message;
 | |
|         $_SESSION['PMA_Theme'] = new Theme();
 | |
|         $GLOBALS['pmaThemeImage'] = 'theme/';
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * Tears down the fixture, for example, closes a network connection.
 | |
|      * This method is called after a test is executed.
 | |
|      *
 | |
|      * @access protected
 | |
|      * @return void
 | |
|      */
 | |
|     protected function tearDown()
 | |
|     {
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * to String casting test
 | |
|      *
 | |
|      * @return void
 | |
|      */
 | |
|     public function testToString()
 | |
|     {
 | |
|         $this->object->setMessage('test<&>', true);
 | |
|         $this->assertEquals('test<&>', (string)$this->object);
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * test success method
 | |
|      *
 | |
|      * @return void
 | |
|      */
 | |
|     public function testSuccess()
 | |
|     {
 | |
|         $this->object = new PMA\libraries\Message('test<&>', PMA\libraries\Message::SUCCESS);
 | |
|         $this->assertEquals($this->object, PMA\libraries\Message::success('test<&>'));
 | |
|         $this->assertEquals(
 | |
|             'Your SQL query has been executed successfully.',
 | |
|             PMA\libraries\Message::success()->getString()
 | |
|         );
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * test error method
 | |
|      *
 | |
|      * @return void
 | |
|      */
 | |
|     public function testError()
 | |
|     {
 | |
|         $this->object = new PMA\libraries\Message('test<&>', PMA\libraries\Message::ERROR);
 | |
|         $this->assertEquals($this->object, PMA\libraries\Message::error('test<&>'));
 | |
|         $this->assertEquals('Error', PMA\libraries\Message::error()->getString());
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * test notice method
 | |
|      *
 | |
|      * @return void
 | |
|      */
 | |
|     public function testNotice()
 | |
|     {
 | |
|         $this->object = new PMA\libraries\Message('test<&>', PMA\libraries\Message::NOTICE);
 | |
|         $this->assertEquals($this->object, PMA\libraries\Message::notice('test<&>'));
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * test rawError method
 | |
|      *
 | |
|      * @return void
 | |
|      */
 | |
|     public function testRawError()
 | |
|     {
 | |
|         $this->object = new PMA\libraries\Message('', PMA\libraries\Message::ERROR);
 | |
|         $this->object->setMessage('test<&>');
 | |
|         $this->object->setBBCode(false);
 | |
| 
 | |
|         $this->assertEquals($this->object, PMA\libraries\Message::rawError('test<&>'));
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * test rawNotice method
 | |
|      *
 | |
|      * @return void
 | |
|      */
 | |
|     public function testRawNotice()
 | |
|     {
 | |
|         $this->object = new PMA\libraries\Message('', PMA\libraries\Message::NOTICE);
 | |
|         $this->object->setMessage('test<&>');
 | |
|         $this->object->setBBCode(false);
 | |
| 
 | |
|         $this->assertEquals($this->object, PMA\libraries\Message::rawNotice('test<&>'));
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * test rawSuccess method
 | |
|      *
 | |
|      * @return void
 | |
|      */
 | |
|     public function testRawSuccess()
 | |
|     {
 | |
|         $this->object = new PMA\libraries\Message('', PMA\libraries\Message::SUCCESS);
 | |
|         $this->object->setMessage('test<&>');
 | |
|         $this->object->setBBCode(false);
 | |
| 
 | |
|         $this->assertEquals($this->object, PMA\libraries\Message::rawSuccess('test<&>'));
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * testing isSuccess method
 | |
|      *
 | |
|      * @return void
 | |
|      */
 | |
|     public function testIsSuccess()
 | |
|     {
 | |
|         $this->assertFalse($this->object->isSuccess());
 | |
|         $this->assertTrue($this->object->isSuccess(true));
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * testing isNotice method
 | |
|      *
 | |
|      * @return void
 | |
|      */
 | |
|     public function testIsNotice()
 | |
|     {
 | |
|         $this->assertTrue($this->object->isNotice());
 | |
|         $this->object->isError(true);
 | |
|         $this->assertFalse($this->object->isNotice());
 | |
|         $this->assertTrue($this->object->isNotice(true));
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * testing isError method
 | |
|      *
 | |
|      * @return void
 | |
|      */
 | |
|     public function testIsError()
 | |
|     {
 | |
|         $this->assertFalse($this->object->isError());
 | |
|         $this->assertTrue($this->object->isError(true));
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * testing setter of message
 | |
|      *
 | |
|      * @return void
 | |
|      */
 | |
|     public function testSetMessage()
 | |
|     {
 | |
|         $this->object->setMessage('test&<>', false);
 | |
|         $this->assertEquals('test&<>', $this->object->getMessage());
 | |
|         $this->object->setMessage('test&<>', true);
 | |
|         $this->assertEquals('test&<>', $this->object->getMessage());
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * testing setter of string
 | |
|      *
 | |
|      * @return void
 | |
|      */
 | |
|     public function testSetString()
 | |
|     {
 | |
|         $this->object->setString('test&<>', false);
 | |
|         $this->assertEquals('test&<>', $this->object->getString());
 | |
|         $this->object->setString('test&<>', true);
 | |
|         $this->assertEquals('test&<>', $this->object->getString());
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * testing add param method
 | |
|      *
 | |
|      * @return void
 | |
|      */
 | |
|     public function testAddParam()
 | |
|     {
 | |
|         $this->object->addParam(PMA\libraries\Message::notice('test'));
 | |
|         $this->assertEquals(
 | |
|             array(PMA\libraries\Message::notice('test')),
 | |
|             $this->object->getParams()
 | |
|         );
 | |
|         $this->object->addParam('test', true);
 | |
|         $this->assertEquals(
 | |
|             array(PMA\libraries\Message::notice('test'), 'test'),
 | |
|             $this->object->getParams()
 | |
|         );
 | |
|         $this->object->addParam('test', false);
 | |
|         $this->assertEquals(
 | |
|             array(PMA\libraries\Message::notice('test'), 'test', PMA\libraries\Message::notice('test')),
 | |
|             $this->object->getParams()
 | |
|         );
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * testing add string method
 | |
|      *
 | |
|      * @return void
 | |
|      */
 | |
|     public function testAddString()
 | |
|     {
 | |
|         $this->object->addString('test', '*');
 | |
|         $this->assertEquals(
 | |
|             array('*', PMA\libraries\Message::notice('test')),
 | |
|             $this->object->getAddedMessages()
 | |
|         );
 | |
|         $this->object->addString('test', '');
 | |
|         $this->assertEquals(
 | |
|             array(
 | |
|                 '*',
 | |
|                 PMA\libraries\Message::notice('test'),
 | |
|                 '',
 | |
|                 PMA\libraries\Message::notice('test')
 | |
|             ),
 | |
|             $this->object->getAddedMessages()
 | |
|         );
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * testing add message method
 | |
|      *
 | |
|      * @return void
 | |
|      */
 | |
|     public function testAddMessage()
 | |
|     {
 | |
|         $this->object->addMessage('test', '');
 | |
|         $this->assertEquals(
 | |
|             array(PMA\libraries\Message::rawNotice('test')),
 | |
|             $this->object->getAddedMessages()
 | |
|         );
 | |
|         $this->object->addMessage('test');
 | |
|         $this->assertEquals(
 | |
|             array(
 | |
|                 PMA\libraries\Message::rawNotice('test'),
 | |
|                 ' ',
 | |
|                 PMA\libraries\Message::rawNotice('test')
 | |
|             ),
 | |
|             $this->object->getAddedMessages()
 | |
|         );
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * testing add messages method
 | |
|      *
 | |
|      * @return void
 | |
|      */
 | |
|     public function testAddMessages()
 | |
|     {
 | |
|         $messages = array();
 | |
|         $messages[] = "Test1";
 | |
|         $messages[] = new PMA\libraries\Message("PMA_Test2", PMA\libraries\Message::ERROR);
 | |
|         $messages[] = "Test3";
 | |
|         $this->object->addMessages($messages, '');
 | |
| 
 | |
|         $this->assertEquals(
 | |
|             array(
 | |
|                 PMA\libraries\Message::rawNotice('Test1'),
 | |
|                 PMA\libraries\Message::error("PMA_Test2"),
 | |
|                 PMA\libraries\Message::rawNotice('Test3')
 | |
|             ),
 | |
|             $this->object->getAddedMessages()
 | |
|         );
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * testing setter of params
 | |
|      *
 | |
|      * @return void
 | |
|      */
 | |
|     public function testSetParams()
 | |
|     {
 | |
|         $this->object->setParams('test&<>');
 | |
|         $this->assertEquals('test&<>', $this->object->getParams());
 | |
|         $this->object->setParams('test&<>', true);
 | |
|         $this->assertEquals('test&<>', $this->object->getParams());
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * testing sanitize method
 | |
|      *
 | |
|      * @return void
 | |
|      */
 | |
|     public function testSanitize()
 | |
|     {
 | |
|         $this->object->setString('test&string<>', false);
 | |
|         $this->assertEquals(
 | |
|             'test&string<>',
 | |
|             PMA\libraries\Message::sanitize($this->object)
 | |
|         );
 | |
|         $this->assertEquals(
 | |
|             array('test&string<>', 'test&string<>'),
 | |
|             PMA\libraries\Message::sanitize(array($this->object, $this->object))
 | |
|         );
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * Data provider for testDecodeBB
 | |
|      *
 | |
|      * @return array Test data
 | |
|      */
 | |
|     public function decodeBBDataProvider()
 | |
|     {
 | |
|         return array(
 | |
|             array(
 | |
|                 '[em]test[/em][em]aa[em/][em]test[/em]',
 | |
|                 '<em>test</em><em>aa[em/]<em>test</em>'
 | |
|             ),
 | |
|             array(
 | |
|                 '[strong]test[/strong][strong]test[/strong]',
 | |
|                 '<strong>test</strong><strong>test</strong>'
 | |
|             ),
 | |
|             array(
 | |
|                 '[code]test[/code][code]test[/code]',
 | |
|                 '<code>test</code><code>test</code>'
 | |
|             ),
 | |
|             array(
 | |
|                 '[kbd]test[/kbd][br][sup]test[/sup]',
 | |
|                 '<kbd>test</kbd><br /><sup>test</sup>'
 | |
|             ),
 | |
|             array(
 | |
|                 '[a@https://example.com/@Documentation]link[/a]',
 | |
|                 '<a href="./url.php?url=https%3A%2F%2Fexample.com%2F"'
 | |
|                 . ' target="Documentation">link</a>'
 | |
|             ),
 | |
|             array(
 | |
|                 '[a@./non-existing@Documentation]link[/a]',
 | |
|                 '[a@./non-existing@Documentation]link</a>'
 | |
|             ),
 | |
|             array(
 | |
|                 '[doc@foo]link[/doc]',
 | |
|                 '<a href="./url.php?url=https%3A%2F%2Fdocs.phpmyadmin.net%2Fen%2F'
 | |
|                 . 'latest%2Fsetup.html%23foo" '
 | |
|                 . 'target="documentation">link</a>'
 | |
|             ),
 | |
|         );
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * testing decodeBB method
 | |
|      *
 | |
|      * @param string $actual   BB code string
 | |
|      * @param string $expected Expected decoded string
 | |
|      *
 | |
|      * @return void
 | |
|      *
 | |
|      * @dataProvider decodeBBDataProvider
 | |
|      */
 | |
|     public function testDecodeBB($actual, $expected)
 | |
|     {
 | |
|         unset($GLOBALS['server']);
 | |
|         unset($GLOBALS['collation_connection']);
 | |
|         $this->assertEquals($expected, PMA\libraries\Message::decodeBB($actual));
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * testing format method
 | |
|      *
 | |
|      * @return void
 | |
|      */
 | |
|     public function testFormat()
 | |
|     {
 | |
|         $this->assertEquals(
 | |
|             'test string',
 | |
|             PMA\libraries\Message::format('test string')
 | |
|         );
 | |
|         $this->assertEquals(
 | |
|             'test string',
 | |
|             PMA\libraries\Message::format('test string', 'a')
 | |
|         );
 | |
|         $this->assertEquals(
 | |
|             'test string',
 | |
|             PMA\libraries\Message::format('test string', array())
 | |
|         );
 | |
|         $this->assertEquals(
 | |
|             'test string',
 | |
|             PMA\libraries\Message::format('%s string', array('test'))
 | |
|         );
 | |
| 
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * testing getHash method
 | |
|      *
 | |
|      * @return void
 | |
|      */
 | |
|     public function testGetHash()
 | |
|     {
 | |
|         $this->object->setString('<&>test', false);
 | |
|         $this->object->setMessage('<&>test', false);
 | |
|         $this->assertEquals(
 | |
|             md5(PMA\libraries\Message::NOTICE . '<&>test<&>test'),
 | |
|             $this->object->getHash()
 | |
|         );
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * getMessage test - with empty message and with non-empty string -
 | |
|      * not key in globals additional params are defined
 | |
|      *
 | |
|      * @return void
 | |
|      */
 | |
|     public function testGetMessageWithoutMessageWithStringWithParams()
 | |
|     {
 | |
|         $this->object->setMessage('');
 | |
|         $this->object->setString('test string %s %s');
 | |
|         $this->object->addParam('test param 1');
 | |
|         $this->object->addParam('test param 2');
 | |
|         $this->assertEquals(
 | |
|             'test string test param 1 test param 2',
 | |
|             $this->object->getMessage()
 | |
|         );
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * getMessage test - with empty message and with empty string
 | |
|      *
 | |
|      * @return void
 | |
|      */
 | |
|     public function testGetMessageWithoutMessageWithEmptyString()
 | |
|     {
 | |
|         $this->object->setMessage('');
 | |
|         $this->object->setString('');
 | |
|         $this->assertEquals('', $this->object->getMessage());
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * getMessage test - with empty message and with string, which is key to GLOBALS
 | |
|      * additional messages are defined
 | |
|      *
 | |
|      * @return void
 | |
|      */
 | |
|     public function testGetMessageWithoutMessageWithGlobalStringWithAddMessages()
 | |
|     {
 | |
|         $GLOBALS['key'] = 'test message';
 | |
|         $this->object->setMessage('');
 | |
|         $this->object->setString('key');
 | |
|         $this->object->addMessage('test message 2', ' - ');
 | |
|         $this->object->addMessage('test message 3', '&');
 | |
|         $this->assertEquals(
 | |
|             'test message - test message 2&test message 3',
 | |
|             $this->object->getMessage()
 | |
|         );
 | |
|         unset($GLOBALS['key']);
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * getMessage test - message is defined
 | |
|      * message with BBCode defined
 | |
|      *
 | |
|      * @return void
 | |
|      */
 | |
|     public function testGetMessageWithMessageWithBBCode()
 | |
|     {
 | |
|         $this->object->setMessage('[kbd]test[/kbd] [doc@cfg_Example]test[/doc]');
 | |
|         $this->assertEquals(
 | |
|             '<kbd>test</kbd> <a href="./url.php?url=https%3A%2F%2Fdocs.phpmyadmin.'
 | |
|             . 'net%2Fen%2Flatest%2Fconfig.html%23cfg_Example"'
 | |
|             . ' target="documentation">test</a>',
 | |
|             $this->object->getMessage()
 | |
|         );
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * getLevel test
 | |
|      *
 | |
|      * @return void
 | |
|      */
 | |
|     public function testGetLevel()
 | |
|     {
 | |
|         $this->assertEquals('notice', $this->object->getLevel());
 | |
|         $this->object->setNumber(PMA\libraries\Message::SUCCESS);
 | |
|         $this->assertEquals('success', $this->object->getLevel());
 | |
|         $this->object->setNumber(PMA\libraries\Message::ERROR);
 | |
|         $this->assertEquals('error', $this->object->getLevel());
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * testing display method (output string and _is_displayed variable)
 | |
|      *
 | |
|      * @return void
 | |
|      */
 | |
|     public function testDisplay()
 | |
|     {
 | |
|         $this->assertFalse($this->object->isDisplayed());
 | |
|         $this->object->setMessage('Test Message');
 | |
| 
 | |
|         $this->expectOutputString(
 | |
|             '<div class="notice"><img src="theme/s_notice.png" title="" alt="" /> '
 | |
|             . 'Test Message</div>'
 | |
|         );
 | |
|         $this->object->display();
 | |
| 
 | |
|         $this->assertTrue($this->object->isDisplayed());
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * getDisplay test
 | |
|      *
 | |
|      * @return void
 | |
|      */
 | |
|     public function testGetDisplay()
 | |
|     {
 | |
|         $this->object->setMessage('Test Message');
 | |
|         $this->assertEquals(
 | |
|             '<div class="notice"><img src="theme/s_notice.png" title="" alt="" /> '
 | |
|             . 'Test Message</div>',
 | |
|             $this->object->getDisplay()
 | |
|         );
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * isDisplayed test
 | |
|      *
 | |
|      * @return void
 | |
|      */
 | |
|     public function testIsDisplayed()
 | |
|     {
 | |
|         $this->assertFalse($this->object->isDisplayed(false));
 | |
|         $this->assertTrue($this->object->isDisplayed(true));
 | |
|         $this->assertTrue($this->object->isDisplayed(false));
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * Data provider for testAffectedRows
 | |
|      *
 | |
|      * @return array Test-data
 | |
|      */
 | |
|     public function providerAffectedRows()
 | |
|     {
 | |
|         return array(
 | |
|             array(
 | |
|                 1,
 | |
|                 '<div class="notice"><img src="theme/s_notice.png" title="" alt="" '
 | |
|                 . '/>  1 row affected.</div>'
 | |
|             ),
 | |
|             array(
 | |
|                 2,
 | |
|                 '<div class="notice"><img src="theme/s_notice.png" title="" alt="" '
 | |
|                 . '/>  2 rows affected.</div>'
 | |
|             ),
 | |
|             array(
 | |
|                 10000,
 | |
|                 '<div class="notice"><img src="theme/s_notice.png" title="" alt="" '
 | |
|                 . '/>  10000 rows affected.</div>'
 | |
|             )
 | |
|         );
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * Test for getMessageForAffectedRows() method
 | |
|      *
 | |
|      * @param int    $rows   Number of rows
 | |
|      * @param string $output Expected string
 | |
|      *
 | |
|      * @return void
 | |
|      *
 | |
|      * @dataProvider providerAffectedRows
 | |
|      */
 | |
|     public function testAffectedRows($rows, $output)
 | |
|     {
 | |
|         $this->object = new PMA\libraries\Message();
 | |
|         $msg = $this->object->getMessageForAffectedRows($rows);
 | |
|         echo $this->object->addMessage($msg);
 | |
|         $this->expectOutputString($output);
 | |
|         $this->object->display();
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * Data provider for testInsertedRows
 | |
|      *
 | |
|      * @return array Test-data
 | |
|      */
 | |
|     public function providerInsertedRows()
 | |
|     {
 | |
|         return array(
 | |
|             array(
 | |
|                 1,
 | |
|                 '<div class="notice"><img src="theme/s_notice.png" title="" alt="" '
 | |
|                 . '/>  1 row inserted.</div>'
 | |
|             ),
 | |
|             array(
 | |
|                 2,
 | |
|                 '<div class="notice"><img src="theme/s_notice.png" title="" alt="" '
 | |
|                 . '/>  2 rows inserted.</div>'
 | |
|             ),
 | |
|             array(
 | |
|                 100000,
 | |
|                 '<div class="notice"><img src="theme/s_notice.png" title="" alt="" '
 | |
|                 . '/>  100000 rows inserted.</div>'
 | |
|             )
 | |
|         );
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * Test for getMessageForInsertedRows() method
 | |
|      *
 | |
|      * @param int    $rows   Number of rows
 | |
|      * @param string $output Expected string
 | |
|      *
 | |
|      * @return void
 | |
|      *
 | |
|      * @dataProvider providerInsertedRows
 | |
|      */
 | |
|     public function testInsertedRows($rows, $output)
 | |
|     {
 | |
|         $this->object = new PMA\libraries\Message();
 | |
|         $msg = $this->object->getMessageForInsertedRows($rows);
 | |
|         echo $this->object->addMessage($msg);
 | |
|         $this->expectOutputString($output);
 | |
|         $this->object->display();
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * Data provider for testDeletedRows
 | |
|      *
 | |
|      * @return array Test-data
 | |
|      */
 | |
|     public function providerDeletedRows()
 | |
|     {
 | |
|         return array(
 | |
|             array(
 | |
|                 1,
 | |
|                 '<div class="notice"><img src="theme/s_notice.png" title="" alt="" '
 | |
|                 . '/>  1 row deleted.</div>'
 | |
|             ),
 | |
|             array(
 | |
|                 2,
 | |
|                 '<div class="notice"><img src="theme/s_notice.png" title="" alt="" '
 | |
|                 . '/>  2 rows deleted.</div>'
 | |
|             ),
 | |
|             array(
 | |
|                 500000,
 | |
|                 '<div class="notice"><img src="theme/s_notice.png" title="" alt="" '
 | |
|                 . '/>  500000 rows deleted.</div>'
 | |
|             )
 | |
|         );
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * Test for getMessageForDeletedRows() method
 | |
|      *
 | |
|      * @param int    $rows   Number of rows
 | |
|      * @param string $output Expected string
 | |
|      *
 | |
|      * @return void
 | |
|      *
 | |
|      * @dataProvider providerDeletedRows
 | |
|      */
 | |
|     public function testDeletedRows($rows, $output)
 | |
|     {
 | |
|         $this->object = new PMA\libraries\Message();
 | |
|         $msg = $this->object->getMessageForDeletedRows($rows);
 | |
|         echo $this->object->addMessage($msg);
 | |
|         $this->expectOutputString($output);
 | |
|         $this->object->display();
 | |
|     }
 | |
| }
 |