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

ReplicationGuiTest.php « classes « test - github.com/phpmyadmin/phpmyadmin.git - Unnamed repository; edit this file 'description' to name the repository.
summaryrefslogtreecommitdiff
blob: 11f01362056932fa0c5c298232a242b05e8b848c (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
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
<?php

declare(strict_types=1);

namespace PhpMyAdmin\Tests;

use PhpMyAdmin\Replication;
use PhpMyAdmin\ReplicationGui;
use PhpMyAdmin\ReplicationInfo;
use PhpMyAdmin\Template;

/**
 * @covers \PhpMyAdmin\ReplicationGui
 */
class ReplicationGuiTest extends AbstractTestCase
{
    /**
     * ReplicationGui instance
     *
     * @var ReplicationGui
     */
    private $replicationGui;

    /**
     * Prepares environment for the test.
     */
    protected function setUp(): void
    {
        parent::setUp();
        //$_POST
        $_POST['primary_add_user'] = 'primary_add_user';

        //$GLOBALS
        $GLOBALS['cfg']['MaxRows'] = 10;
        $GLOBALS['cfg']['ServerDefault'] = 'server';
        $GLOBALS['cfg']['RememberSorting'] = true;
        $GLOBALS['cfg']['SQP'] = [];
        $GLOBALS['cfg']['MaxCharactersInDisplayedSQL'] = 1000;
        $GLOBALS['cfg']['ShowSQL'] = true;
        $GLOBALS['cfg']['TableNavigationLinksMode'] = 'icons';
        $GLOBALS['cfg']['LimitChars'] = 100;
        $GLOBALS['cfg']['DBG']['sql'] = false;
        $GLOBALS['cfg']['ShowHint'] = true;

        $GLOBALS['table'] = 'table';
        $GLOBALS['server'] = 0;
        $GLOBALS['urlParams'] = [];

        $this->replicationGui = new ReplicationGui(new Replication(), new Template());
    }

    /**
     * @group medium
     */
    public function testGetHtmlForPrimaryReplication(): void
    {
        $html = $this->replicationGui->getHtmlForPrimaryReplication();

        //validate 1: Primary replication
        $this->assertStringContainsString('<div class="card-header">Primary replication</div>', $html);
        $this->assertStringContainsString('This server is configured as primary in a replication process.', $html);

        //validate 2: getHtmlForReplicationStatusTable
        $this->assertStringContainsString('<div id="replication_primary_section"', $html);

        $this->assertStringContainsString('Binlog_Do_DB', $html);
        $this->assertStringContainsString('Binlog_Ignore_DB', $html);

        $this->assertStringContainsString('primary-bin.000030', $html);

        //validate 3: getHtmlForReplicationReplicasTable
        $this->assertStringContainsString('replication_replicas_section', $html);
        $this->assertStringContainsString('<th>Server ID</th>', $html);
        $this->assertStringContainsString('<th>Host</th>', $html);
        //replica host
        $this->assertStringContainsString('<td class="text-end font-monospace">Server_id1</td>', $html);
        $this->assertStringContainsString('<td class="text-end font-monospace">Server_id2</td>', $html);
        $this->assertStringContainsString('<td class="text-end font-monospace">Host1</td>', $html);
        $this->assertStringContainsString('<td class="text-end font-monospace">Host2</td>', $html);
        //Notice
        $this->assertStringContainsString('Only replicas started with the', $html);

        //validate 4: navigation URL
        $this->assertStringContainsString('<a href="index.php?route=/server/replication', $html);
        $this->assertStringContainsString('Add replica replication user', $html);

        //validate 5: 'Add replication replica user' form
        $this->assertStringContainsString('<div id="primary_addreplicauser_gui">', $html);
    }

    public function testGetHtmlForReplicaConfiguration(): void
    {
        $replicationInfo = new ReplicationInfo($GLOBALS['dbi']);
        $replicationInfo->load();

        //Call the test function
        $html = $this->replicationGui->getHtmlForReplicaConfiguration(
            true,
            $replicationInfo->getReplicaStatus()
        );

        //legend
        $this->assertStringContainsString('<div class="card-header">Replica replication</div>', $html);
        $this->assertStringContainsString('<div id="replica_configuration_gui">', $html);
        //notice
        $this->assertStringContainsString('Server is configured as replica in a replication process.', $html);
        //replica session
        $this->assertStringContainsString('<div id="replication_replica_section"', $html);
        //variable
        $this->assertStringContainsString('Master_SSL_CA_Path', $html);
        $this->assertStringContainsString('Master_SSL_Cert', $html);
        $this->assertStringContainsString('Master_SSL_Cipher', $html);
        $this->assertStringContainsString('Seconds_Behind_Master', $html);
    }

    public function testGetHtmlForReplicationChangePrimary(): void
    {
        //Call the test function
        $html = $this->replicationGui->getHtmlForReplicationChangePrimary('replica_changeprimary');

        $this->assertStringContainsString('<form method="post" action="index.php?route=/server/replication', $html);
        $this->assertStringContainsString('Replica configuration', $html);
        $this->assertStringContainsString('Change or reconfigure primary server', $html);
        $notice = 'Make sure you have a unique server-id in your configuration file (my.cnf)';
        $this->assertStringContainsString($notice, $html);
    }
}