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);
    }
}