54 Zeilen
		
	
	
		
			Kein EOL
		
	
	
		
			2,1 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
			
		
		
	
	
			54 Zeilen
		
	
	
		
			Kein EOL
		
	
	
		
			2,1 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
| <?php
 | |
| /**
 | |
|  * @group Sql
 | |
|  */
 | |
| class Msd_Application_Controller_SqlControllerTest
 | |
|     extends ControllerTestCase
 | |
| {
 | |
|     public function testCanShowDatabaseList()
 | |
|     {
 | |
|         $this->loginUser();
 | |
|         $this->dispatch('sql');
 | |
|         // make sure headline of db list is shown with correct user
 | |
|         $expected = "Datenbanken des Benutzers 'root'@'localhost'";
 | |
|         $this->assertQueryContentContains('h2', $expected);
 | |
|         // make sure we see the "show tables" link for db information_schema
 | |
|         $expected = base64_encode("information_schema");
 | |
|         $this->assertXpath("//a[contains(@href, '" . $expected ."')]");
 | |
|     }
 | |
| 
 | |
|     public function testCanShowTableList()
 | |
|     {
 | |
|         $this->loginUser();
 | |
|         $this->dispatch('sql/show.tables/dbName/bXlzcWw%3D');
 | |
|         // make sure headline shows the selected database
 | |
|         $expected = 'Tabellen der Datenbank `mysql`';
 | |
|         $this->assertQueryContentContains('h2', $expected);
 | |
|         // make sure we see the detail link for table `mysql`.`db`
 | |
|         $expected = 'columns_priv';
 | |
|         $this->assertQueryContentContains('table > tr > td > label', $expected);
 | |
|     }
 | |
| 
 | |
|     public function testCanShowTableData()
 | |
|     {
 | |
|         $this->loginUser();
 | |
|         $this->dispatch('sql/show.table.data/dbName/bXlzcWw%3D/tableName/dXNlcg%3D%3D');
 | |
|         // make sure headline shows the selected table
 | |
|         $expected = 'Datensätze der Tabelle `mysql`.`user`';
 | |
|         $this->assertQueryContentContains('h2', $expected);
 | |
|         // make sure user root@localhost is shown
 | |
|         $expected = 'localhost        ';
 | |
|         $this->assertQueryContentContains('table > tr > td', $expected);
 | |
|         $expected = 'root        ';
 | |
|         $this->assertQueryContentContains('table > tr > td', $expected);
 | |
|     }
 | |
| 
 | |
|     public function testCanFallbackToShowingDataOfFirstTableOnIncorrectTable()
 | |
|     {
 | |
|         $this->loginUser();
 | |
|         $this->dispatch('sql/show.table.data/dbName/bXlzcWw%3D/tableName/iDontExits');
 | |
|         // we excpect a fall back to the first found table in db `mysql`
 | |
|         $expected = 'Datensätze der Tabelle `mysql`.`columns_priv`';
 | |
|         $this->assertQueryContentContains('h2', $expected);
 | |
|     }
 | |
| } |