Initial commit
This commit is contained in:
270
#pma/test/libraries/PMA_server_user_groups_test.php
Normal file
270
#pma/test/libraries/PMA_server_user_groups_test.php
Normal file
@ -0,0 +1,270 @@
|
||||
<?php
|
||||
/* vim: set expandtab sw=4 ts=4 sts=4: */
|
||||
/**
|
||||
* Tests for server_user_groups.lib.php
|
||||
*
|
||||
* @package PhpMyAdmin-test
|
||||
*/
|
||||
|
||||
use PMA\libraries\Theme;
|
||||
|
||||
|
||||
|
||||
require_once 'libraries/relation.lib.php';
|
||||
require_once 'libraries/database_interface.inc.php';
|
||||
require_once 'libraries/url_generating.lib.php';
|
||||
/*
|
||||
* Include to test.
|
||||
*/
|
||||
require_once 'libraries/server_user_groups.lib.php';
|
||||
|
||||
/**
|
||||
* Tests for server_user_groups.lib.php
|
||||
*
|
||||
* @package PhpMyAdmin-test
|
||||
*/
|
||||
class PMA_ServerUserGroupsTest extends PHPUnit_Framework_TestCase
|
||||
{
|
||||
/**
|
||||
* Prepares environment for the test.
|
||||
*
|
||||
* @return void
|
||||
*/
|
||||
public function setUp()
|
||||
{
|
||||
$GLOBALS['cfg']['ServerDefault'] = 1;
|
||||
$GLOBALS['cfg']['ActionLinksMode'] = 'both';
|
||||
|
||||
$GLOBALS['server'] = 1;
|
||||
$_SESSION['relation'][$GLOBALS['server']] = array(
|
||||
'PMA_VERSION' => PMA_VERSION,
|
||||
'db' => 'pmadb',
|
||||
'users' => 'users',
|
||||
'usergroups' => 'usergroups'
|
||||
);
|
||||
|
||||
$GLOBALS['pmaThemeImage'] = 'image';
|
||||
$_SESSION['PMA_Theme'] = Theme::load('./themes/pmahomme');
|
||||
$_SESSION['PMA_Theme'] = new Theme();
|
||||
}
|
||||
|
||||
/**
|
||||
* Tests PMA_getHtmlForUserGroupsTable() function when there are no user groups
|
||||
*
|
||||
* @return void
|
||||
* @group medium
|
||||
*/
|
||||
public function testGetHtmlForUserGroupsTableWithNoUserGroups()
|
||||
{
|
||||
$expectedQuery = "SELECT * FROM `pmadb`.`usergroups`"
|
||||
. " ORDER BY `usergroup` ASC";
|
||||
|
||||
$dbi = $this->getMockBuilder('PMA\libraries\DatabaseInterface')
|
||||
->disableOriginalConstructor()
|
||||
->getMock();
|
||||
$dbi->expects($this->once())
|
||||
->method('tryQuery')
|
||||
->with($expectedQuery)
|
||||
->will($this->returnValue(true));
|
||||
$dbi->expects($this->once())
|
||||
->method('numRows')
|
||||
->withAnyParameters()
|
||||
->will($this->returnValue(0));
|
||||
$dbi->expects($this->once())
|
||||
->method('freeResult');
|
||||
$GLOBALS['dbi'] = $dbi;
|
||||
|
||||
$html = PMA_getHtmlForUserGroupsTable();
|
||||
$this->assertNotContains(
|
||||
'<table id="userGroupsTable">',
|
||||
$html
|
||||
);
|
||||
$url_tag = '<a href="server_user_groups.php'
|
||||
. PMA_URL_getCommon(array('addUserGroup' => 1));
|
||||
$this->assertContains(
|
||||
$url_tag,
|
||||
$html
|
||||
);
|
||||
}
|
||||
|
||||
/**
|
||||
* Tests PMA_getHtmlForUserGroupsTable() function when there are user groups
|
||||
*
|
||||
* @return void
|
||||
*/
|
||||
public function testGetHtmlForUserGroupsTableWithUserGroups()
|
||||
{
|
||||
$expectedQuery = "SELECT * FROM `pmadb`.`usergroups`"
|
||||
. " ORDER BY `usergroup` ASC";
|
||||
|
||||
$dbi = $this->getMockBuilder('PMA\libraries\DatabaseInterface')
|
||||
->disableOriginalConstructor()
|
||||
->getMock();
|
||||
$dbi->expects($this->once())
|
||||
->method('tryQuery')
|
||||
->with($expectedQuery)
|
||||
->will($this->returnValue(true));
|
||||
$dbi->expects($this->once())
|
||||
->method('numRows')
|
||||
->withAnyParameters()
|
||||
->will($this->returnValue(1));
|
||||
$dbi->expects($this->at(2))
|
||||
->method('fetchAssoc')
|
||||
->withAnyParameters()
|
||||
->will(
|
||||
$this->returnValue(
|
||||
array(
|
||||
'usergroup' => 'usergroup',
|
||||
'tab' => 'server_sql',
|
||||
'allowed' => 'Y'
|
||||
)
|
||||
)
|
||||
);
|
||||
$dbi->expects($this->at(3))
|
||||
->method('fetchAssoc')
|
||||
->withAnyParameters()
|
||||
->will($this->returnValue(false));
|
||||
$dbi->expects($this->once())
|
||||
->method('freeResult');
|
||||
$GLOBALS['dbi'] = $dbi;
|
||||
|
||||
$html = PMA_getHtmlForUserGroupsTable();
|
||||
$this->assertContains(
|
||||
'<td>usergroup</td>',
|
||||
$html
|
||||
);
|
||||
$url_tag = '<a class="" href="server_user_groups.php'
|
||||
. PMA_URL_getCommon(
|
||||
array(
|
||||
'viewUsers'=>1, 'userGroup'=>htmlspecialchars('usergroup')
|
||||
)
|
||||
);
|
||||
$this->assertContains(
|
||||
$url_tag,
|
||||
$html
|
||||
);
|
||||
$url_tag = '<a class="" href="server_user_groups.php'
|
||||
. PMA_URL_getCommon(
|
||||
array(
|
||||
'editUserGroup'=>1,
|
||||
'userGroup'=>htmlspecialchars('usergroup')
|
||||
)
|
||||
);
|
||||
$this->assertContains(
|
||||
$url_tag,
|
||||
$html
|
||||
);
|
||||
$url_tag = '<a class="deleteUserGroup ajax" href="server_user_groups.php'
|
||||
. PMA_URL_getCommon(
|
||||
array(
|
||||
'deleteUserGroup'=> 1,
|
||||
'userGroup'=>htmlspecialchars('usergroup')
|
||||
)
|
||||
);
|
||||
$this->assertContains(
|
||||
$url_tag,
|
||||
$html
|
||||
);
|
||||
}
|
||||
|
||||
/**
|
||||
* Tests PMA_deleteUserGroup() function
|
||||
*
|
||||
* @return void
|
||||
*/
|
||||
public function testDeleteUserGroup()
|
||||
{
|
||||
$userDelQuery = "DELETE FROM `pmadb`.`users`"
|
||||
. " WHERE `usergroup`='ug'";
|
||||
$userGrpDelQuery = "DELETE FROM `pmadb`.`usergroups`"
|
||||
. " WHERE `usergroup`='ug'";
|
||||
|
||||
$dbi = $this->getMockBuilder('PMA\libraries\DatabaseInterface')
|
||||
->disableOriginalConstructor()
|
||||
->getMock();
|
||||
$dbi->expects($this->at(1))
|
||||
->method('query')
|
||||
->with($userDelQuery);
|
||||
$dbi->expects($this->at(3))
|
||||
->method('query')
|
||||
->with($userGrpDelQuery);
|
||||
$dbi->expects($this->any())
|
||||
->method('escapeString')
|
||||
->will($this->returnArgument(0));
|
||||
|
||||
$GLOBALS['dbi'] = $dbi;
|
||||
|
||||
PMA_deleteUserGroup('ug');
|
||||
}
|
||||
|
||||
/**
|
||||
* Tests PMA_getHtmlToEditUserGroup() function
|
||||
*
|
||||
* @return void
|
||||
*/
|
||||
public function testGetHtmlToEditUserGroup()
|
||||
{
|
||||
// adding a user group
|
||||
$html = PMA_getHtmlToEditUserGroup();
|
||||
$this->assertContains(
|
||||
'<input type="hidden" name="addUserGroupSubmit" value="1"',
|
||||
$html
|
||||
);
|
||||
$this->assertContains(
|
||||
'<input type="text" name="userGroup"',
|
||||
$html
|
||||
);
|
||||
|
||||
$expectedQuery = "SELECT * FROM `pmadb`.`usergroups`"
|
||||
. " WHERE `usergroup`='ug'";
|
||||
$dbi = $this->getMockBuilder('PMA\libraries\DatabaseInterface')
|
||||
->disableOriginalConstructor()
|
||||
->getMock();
|
||||
$dbi->expects($this->once())
|
||||
->method('tryQuery')
|
||||
->with($expectedQuery)
|
||||
->will($this->returnValue(true));
|
||||
$dbi->expects($this->exactly(2))
|
||||
->method('fetchAssoc')
|
||||
->willReturnOnConsecutiveCalls(
|
||||
array(
|
||||
'usergroup' => 'ug',
|
||||
'tab' => 'server_sql',
|
||||
'allowed' => 'Y'
|
||||
),
|
||||
false
|
||||
);
|
||||
$dbi->expects($this->once())
|
||||
->method('freeResult');
|
||||
$dbi->expects($this->any())
|
||||
->method('escapeString')
|
||||
->will($this->returnArgument(0));
|
||||
|
||||
$GLOBALS['dbi'] = $dbi;
|
||||
|
||||
// editing a user group
|
||||
$html = PMA_getHtmlToEditUserGroup('ug');
|
||||
$this->assertContains(
|
||||
'<input type="hidden" name="userGroup" value="ug"',
|
||||
$html
|
||||
);
|
||||
$this->assertContains(
|
||||
'<input type="hidden" name="editUserGroupSubmit" value="1"',
|
||||
$html
|
||||
);
|
||||
$this->assertContains(
|
||||
'<input type="hidden" name="editUserGroupSubmit" value="1"',
|
||||
$html
|
||||
);
|
||||
$this->assertContains(
|
||||
'<input type="checkbox" class="checkall" checked="checked"'
|
||||
. ' name="server_sql" value="Y" />',
|
||||
$html
|
||||
);
|
||||
$this->assertContains(
|
||||
'<input type="checkbox" class="checkall"'
|
||||
. ' name="server_databases" value="Y" />',
|
||||
$html
|
||||
);
|
||||
}
|
||||
}
|
Reference in New Issue
Block a user