76 lines
1.9 KiB
PHP
76 lines
1.9 KiB
PHP
|
<?php
|
||
|
|
||
|
namespace Symfony\Component\Security\Acl\Domain;
|
||
|
|
||
|
class AuditLoggerTest extends \PHPUnit_Framework_TestCase
|
||
|
{
|
||
|
/**
|
||
|
* @dataProvider getTestLogData
|
||
|
*/
|
||
|
public function testLogIfNeeded($granting, $audit)
|
||
|
{
|
||
|
$logger = $this->getLogger();
|
||
|
$ace = $this->getEntry();
|
||
|
|
||
|
if (true === $granting) {
|
||
|
$ace
|
||
|
->expects($this->once())
|
||
|
->method('isAuditSuccess')
|
||
|
->will($this->returnValue($audit))
|
||
|
;
|
||
|
|
||
|
$ace
|
||
|
->expects($this->never())
|
||
|
->method('isAuditFailure')
|
||
|
;
|
||
|
}
|
||
|
else {
|
||
|
$ace
|
||
|
->expects($this->never())
|
||
|
->method('isAuditSuccess')
|
||
|
;
|
||
|
|
||
|
$ace
|
||
|
->expects($this->once())
|
||
|
->method('isAuditFailure')
|
||
|
->will($this->returnValue($audit))
|
||
|
;
|
||
|
}
|
||
|
|
||
|
if (true === $audit) {
|
||
|
$logger
|
||
|
->expects($this->once())
|
||
|
->method('doLog')
|
||
|
->with($this->equalTo($granting), $this->equalTo($ace))
|
||
|
;
|
||
|
}
|
||
|
else {
|
||
|
$logger
|
||
|
->expects($this->never())
|
||
|
->method('doLog')
|
||
|
;
|
||
|
}
|
||
|
|
||
|
$logger->logIfNeeded($granting, $ace);
|
||
|
}
|
||
|
|
||
|
public function getTestLogData()
|
||
|
{
|
||
|
return array(
|
||
|
array(true, false),
|
||
|
array(true, true),
|
||
|
array(false, false),
|
||
|
array(false, true),
|
||
|
);
|
||
|
}
|
||
|
|
||
|
protected function getEntry()
|
||
|
{
|
||
|
return $this->getMock('Symfony\Component\Security\Acl\Model\AuditableEntryInterface');
|
||
|
}
|
||
|
|
||
|
protected function getLogger()
|
||
|
{
|
||
|
return $this->getMockForAbstractClass('Symfony\Component\Security\Acl\Domain\AuditLogger');
|
||
|
}
|
||
|
}
|