271 lines
7.9 KiB
PHP
271 lines
7.9 KiB
PHP
<?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
|
|
);
|
|
}
|
|
}
|