Spaces:
No application file
No application file
File size: 3,203 Bytes
d2897cd |
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 |
<?php
namespace Mautic\ConfigBundle\Tests\Service;
use Mautic\ConfigBundle\Service\ConfigChangeLogger;
use Mautic\CoreBundle\Helper\IpLookupHelper;
use Mautic\CoreBundle\Model\AuditLogModel;
class ConfigChangeLoggerTest extends \PHPUnit\Framework\TestCase
{
public function testSetOriginalNormData(): void
{
$ipLookupHelper = $this->createMock(IpLookupHelper::class);
$auditLogModel = $this->createMock(AuditLogModel::class);
$logger = new ConfigChangeLogger($ipLookupHelper, $auditLogModel);
$this->assertEquals($logger, $logger->setOriginalNormData([]));
}
public function testOriginalNormDataExpected(): void
{
$this->expectException(\RuntimeException::class);
$ipLookupHelper = $this->createMock(IpLookupHelper::class);
$ipLookupHelper->expects($this->never())->method('getIpAddressFromRequest');
$auditLogModel = $this->createMock(AuditLogModel::class);
$auditLogModel->expects($this->never())->method('writeToLog');
$logger = new ConfigChangeLogger($ipLookupHelper, $auditLogModel);
$logger->log([]);
}
public function testNothingToLog(): void
{
$ipLookupHelper = $this->createMock(IpLookupHelper::class);
$ipLookupHelper->expects($this->never())->method('getIpAddressFromRequest');
$auditLogModel = $this->createMock(AuditLogModel::class);
$auditLogModel->expects($this->never())->method('writeToLog');
$logger = new ConfigChangeLogger($ipLookupHelper, $auditLogModel);
$originalData = $postData = [
'bundle' => [
'key' => 'value',
],
];
$this->assertEquals($logger, $logger->setOriginalNormData($originalData));
$logger->log($postData);
}
public function testLog(): void
{
$change = [
'key2' => 'changedValue',
];
$filterMe = [
'transifex_password' => 'dhjsakjfda',
'mailer_is_owner' => 'lksajhd',
];
$log = [
'bundle' => 'config',
'object' => 'config',
'objectId' => 0,
'action' => 'update',
'details' => $change,
'ipAddress' => null,
];
$ipLookupHelper = $this->createMock(IpLookupHelper::class);
$ipLookupHelper->expects($this->once())->method('getIpAddressFromRequest');
$auditLogModel = $this->createMock(AuditLogModel::class);
$auditLogModel->expects($this->once())->method('writeToLog')->with($log);
$logger = new ConfigChangeLogger($ipLookupHelper, $auditLogModel);
$originalData = [
'bundle' => [
'key' => 'value',
],
'bundle2' => [
'parameters' => [
'key2' => 'value2',
],
],
];
$postData = [
'bundle' => [
'key' => 'value',
],
'bundle2' => array_merge($change, $filterMe),
];
$this->assertEquals($logger, $logger->setOriginalNormData($originalData));
$logger->log($postData);
}
}
|