Welcome to mirror list, hosted at ThFree Co, Russian Federation.

DuplicateActionRemoverTest.php « Model « Integration « tests « CoreAdminHome « plugins - github.com/matomo-org/matomo.git - Unnamed repository; edit this file 'description' to name the repository.
summaryrefslogtreecommitdiff
blob: 7add6d62476e6a61e609e869aecef1db9c670226 (plain)
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
99
100
101
102
103
104
105
106
107
108
109
110
111
112
<?php
/**
 * Piwik - free/libre analytics platform
 *
 * @link https://matomo.org
 * @license http://www.gnu.org/licenses/gpl-3.0.html GPL v3 or later
 */
namespace Piwik\Plugins\CoreAdminHome\tests\Integration\Model;

use Piwik\Common;
use Piwik\Db;
use Piwik\Plugins\CoreAdminHome\Model\DuplicateActionRemover;
use Piwik\Plugins\CoreAdminHome\tests\Fixture\DuplicateActions;
use Piwik\Tests\Framework\TestCase\IntegrationTestCase;

/**
 * @group Core
 */
class DuplicateActionRemoverTest extends IntegrationTestCase
{
    /**
     * @var DuplicateActions
     */
    public static $fixture = null;

    /**
     * @var DuplicateActionRemover
     */
    private $duplicateActionRemover;

    public function setUp(): void
    {
        parent::setUp();

        $this->duplicateActionRemover = new DuplicateActionRemover();
    }

    public function test_getDuplicateIdActions_ReturnsDuplicateIdActions_AndTreatsLowestIdActionAsOriginal()
    {
        $expectedResult = array(
            array('name' => 'action1', 'idaction' => 1, 'duplicateIdActions' => array(2, 3)),
            array('name' => 'ACTION2', 'idaction' => 5, 'duplicateIdActions' => array(7, 11)),
            array('name' => 'action2', 'idaction' => 4, 'duplicateIdActions' => array(9)),
            array('name' => 'action4', 'idaction' => 6, 'duplicateIdActions' => array(10, 12)),
        );
        $actualResult = $this->duplicateActionRemover->getDuplicateIdActions();
        $this->assertEquals($expectedResult, $actualResult);
    }

    public function test_fixDuplicateActionsInTable_CorrectlyUpdatesIdActionColumns_InSpecifiedTable()
    {
        $this->duplicateActionRemover->fixDuplicateActionsInTable('log_conversion_item', 5, array(3, 6, 7, 10));

        $columns = array('idaction_sku', 'idaction_name', 'idaction_category', 'idaction_category2',
                         'idaction_category3', 'idaction_category4', 'idaction_category5');

        $expectedResult = array(
            array(
                'idaction_sku' => '1',
                'idaction_name' => '2',
                'idaction_category' => '5',
                'idaction_category2' => '4',
                'idaction_category3' => '5',
                'idaction_category4' => '5',
                'idaction_category5' => '5'
            ),
            array(
                'idaction_sku' => '2',
                'idaction_name' => '5',
                'idaction_category' => '5',
                'idaction_category2' => '5',
                'idaction_category3' => '8',
                'idaction_category4' => '9',
                'idaction_category5' => '5'
            ),
        );
        $actualResult = Db::fetchAll("SELECT " . implode(", ", $columns) . " FROM " . Common::prefixTable('log_conversion_item'));
        $this->assertEquals($expectedResult, $actualResult);
    }

    public function test_getSitesAndDatesOfRowsUsingDuplicates_ReturnsTheServerTimeAndIdSite_OfRowsUsingSpecifiedActionIds()
    {
        $row = array(
            'idsite' => 3,
            'idvisitor' => pack("H*", DuplicateActions::DUMMY_IDVISITOR),
            'server_time' => '2012-02-13 00:00:00',
            'idvisit' => 5,
            'idorder' => 6,
            'price' => 15,
            'quantity' => 21,
            'deleted' => 1,
            'idaction_sku' => 3,
            'idaction_name' => 3,
            'idaction_category' => 12,
            'idaction_category2' => 3,
            'idaction_category3' => 3,
            'idaction_category4' => 3,
            'idaction_category5' => 3,
        );
        Db::query("INSERT INTO " . Common::prefixTable('log_conversion_item') . " (" . implode(", ", array_keys($row))
            . ") VALUES ('" . implode("', '", array_values($row)) . "')");

        $expectedResult = array(
            array('idsite' => 1, 'server_time' => '2012-02-01'),
            array('idsite' => 3, 'server_time' => '2012-02-13')
        );
        $actualResult = $this->duplicateActionRemover->getSitesAndDatesOfRowsUsingDuplicates('log_conversion_item', array(4, 6, 12));
        $this->assertEquals($expectedResult, $actualResult);
    }
}

DuplicateActionRemoverTest::$fixture = new DuplicateActions();