Initial commit
This commit is contained in:
		
							
								
								
									
										198
									
								
								#pma/test/classes/IndexTest.php
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										198
									
								
								#pma/test/classes/IndexTest.php
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,198 @@ | ||||
| <?php | ||||
| /* vim: set expandtab sw=4 ts=4 sts=4: */ | ||||
| /** | ||||
|  * Test for Index class | ||||
|  * | ||||
|  * @package PhpMyAdmin-test | ||||
|  */ | ||||
|  | ||||
| /* | ||||
|  * Include to test. | ||||
|  */ | ||||
| require_once 'test/PMATestCase.php'; | ||||
|  | ||||
| /** | ||||
|  * Test for Index class | ||||
|  * | ||||
|  * @package PhpMyAdmin-test | ||||
|  */ | ||||
| class IndexTest extends PMATestCase | ||||
| { | ||||
|     private $_params = array(); | ||||
|  | ||||
|     /** | ||||
|      * Configures parameters. | ||||
|      * | ||||
|      * @return void | ||||
|      */ | ||||
|     public function setup() | ||||
|     { | ||||
|         $this->_params['Schema'] = "PMA_Schema"; | ||||
|         $this->_params['Table'] = "PMA_Table"; | ||||
|         $this->_params['Key_name'] = "PMA_Key_name"; | ||||
|         $this->_params['Index_choice'] = "PMA_Index_choice"; | ||||
|         $this->_params['Comment'] = "PMA_Comment"; | ||||
|         $this->_params['Index_comment'] = "PMA_Index_comment"; | ||||
|         $this->_params['Non_unique'] = "PMA_Non_unique"; | ||||
|         $this->_params['Packed'] = "PMA_Packed"; | ||||
|  | ||||
|         //test add columns | ||||
|         $column1 = array("Column_name"=>"column1","Seq_in_index"=>"index1", | ||||
|                          "Collation"=>"Collation1","Cardinality"=>"Cardinality1", | ||||
|                          "Null"=>"null1" | ||||
|                         ); | ||||
|         $column2 = array("Column_name"=>"column2","Seq_in_index"=>"index2", | ||||
|                          "Collation"=>"Collation2","Cardinality"=>"Cardinality2", | ||||
|                          "Null"=>"null2" | ||||
|                         ); | ||||
|         $column3 = array("Column_name"=>"column3","Seq_in_index"=>"index3", | ||||
|                          "Collation"=>"Collation3","Cardinality"=>"Cardinality3", | ||||
|                          "Null"=>"null3" | ||||
|                         ); | ||||
|         $this->_params['columns'][] = $column1; | ||||
|         $this->_params['columns'][] = $column2; | ||||
|         $this->_params['columns'][] = $column3; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Test for Constructor | ||||
|      * | ||||
|      * @return void | ||||
|      */ | ||||
|     public function testConstructor() | ||||
|     { | ||||
|         $index = new PMA\libraries\Index($this->_params); | ||||
|         $this->assertEquals( | ||||
|             'PMA_Index_comment', | ||||
|             $index->getComment() | ||||
|         ); | ||||
|         $this->assertEquals( | ||||
|             'PMA_Comment', | ||||
|             $index->getRemarks() | ||||
|         ); | ||||
|         $this->assertEquals( | ||||
|             'PMA_Index_choice', | ||||
|             $index->getChoice() | ||||
|         ); | ||||
|         $this->assertEquals( | ||||
|             'PMA_Packed', | ||||
|             $index->getPacked() | ||||
|         ); | ||||
|         $this->assertEquals( | ||||
|             'PMA_Non_unique', | ||||
|             $index->getNonUnique() | ||||
|         ); | ||||
|         $this->assertContains( | ||||
|             'PMA_Comment', | ||||
|             $index->getComments() | ||||
|         ); | ||||
|         $this->assertContains( | ||||
|             'PMA_Index_comment', | ||||
|             $index->getComments() | ||||
|         ); | ||||
|         $this->assertEquals( | ||||
|             'PMA_Index_choice', | ||||
|             $index->getChoice() | ||||
|         ); | ||||
|  | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Test for getIndexChoices | ||||
|      * | ||||
|      * @return void | ||||
|      */ | ||||
|     public function testGetIndexChoices() | ||||
|     { | ||||
|         $index_choices = PMA\libraries\Index::getIndexChoices(); | ||||
|         $this->assertEquals( | ||||
|             5, | ||||
|             count($index_choices) | ||||
|         ); | ||||
|         $this->assertEquals( | ||||
|             'PRIMARY,INDEX,UNIQUE,SPATIAL,FULLTEXT', | ||||
|             implode(",", $index_choices) | ||||
|         ); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Test for isUnique | ||||
|      * | ||||
|      * @return void | ||||
|      */ | ||||
|     public function testIsUniquer() | ||||
|     { | ||||
|         $this->_params['Non_unique'] = "0"; | ||||
|         $index = new PMA\libraries\Index($this->_params); | ||||
|         $this->assertTrue( | ||||
|             $index->isUnique() | ||||
|         ); | ||||
|         $this->assertEquals( | ||||
|             'Yes', | ||||
|             $index->isUnique(true) | ||||
|         ); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Test for add Columns | ||||
|      * | ||||
|      * @return void | ||||
|      */ | ||||
|     public function testAddColumns() | ||||
|     { | ||||
|         $index = new PMA\libraries\Index(); | ||||
|         $index->addColumns($this->_params['columns']); | ||||
|         $this->assertTrue($index->hasColumn("column1")); | ||||
|         $this->assertTrue($index->hasColumn("column2")); | ||||
|         $this->assertTrue($index->hasColumn("column3")); | ||||
|         $this->assertEquals( | ||||
|             3, | ||||
|             $index->getColumnCount() | ||||
|         ); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Test for get Name & set Name | ||||
|      * | ||||
|      * @return void | ||||
|      */ | ||||
|     public function testName() | ||||
|     { | ||||
|         $index = new PMA\libraries\Index(); | ||||
|         $index->setName('PMA_name'); | ||||
|         $this->assertEquals( | ||||
|             'PMA_name', | ||||
|             $index->getName() | ||||
|         ); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Test for PMA\libraries\Index_Column | ||||
|      * | ||||
|      * @return void | ||||
|      */ | ||||
|     public function testColumns() | ||||
|     { | ||||
|         $index = new PMA\libraries\Index(); | ||||
|         $index->addColumns($this->_params['columns']); | ||||
|  | ||||
|         $index_columns = $index->getColumns(); | ||||
|         $index_column = $index_columns['column1']; | ||||
|         $this->assertEquals( | ||||
|             'column1', | ||||
|             $index_column->getName() | ||||
|         ); | ||||
|         $this->assertEquals( | ||||
|             'index1', | ||||
|             $index_column->getSeqInIndex() | ||||
|         ); | ||||
|         $this->assertEquals( | ||||
|             'Collation1', | ||||
|             $index_column->getCollation() | ||||
|         ); | ||||
|         $this->assertEquals( | ||||
|             'Cardinality1', | ||||
|             $index_column->getCardinality() | ||||
|         ); | ||||
|     } | ||||
| } | ||||
		Reference in New Issue
	
	Block a user