general_plugin_issuelinks_test::test_plugin_conf()   B
last analyzed

Complexity

Conditions 7
Paths 20

Size

Total Lines 23
Code Lines 15

Duplication

Lines 0
Ratio 0 %

Importance

Changes 1
Bugs 0 Features 1
Metric Value
cc 7
eloc 15
c 1
b 0
f 1
nc 20
nop 0
dl 0
loc 23
rs 8.8333
1
<?php
2
3
/**
4
 * General tests for the issuelinks plugin
5
 *
6
 * @group plugin_issuelinks
7
 * @group plugins
8
 */
9
class general_plugin_issuelinks_test extends DokuWikiTest
10
{
11
12
    /**
13
     * Simple test to make sure the plugin.info.txt is in correct format
14
     */
15
    public function test_plugininfo()
16
    {
17
        $file = __DIR__ . '/../plugin.info.txt';
18
        $this->assertFileExists($file);
19
20
        $info = confToHash($file);
21
22
        $this->assertArrayHasKey('base', $info);
23
        $this->assertArrayHasKey('author', $info);
24
        $this->assertArrayHasKey('email', $info);
25
        $this->assertArrayHasKey('date', $info);
26
        $this->assertArrayHasKey('name', $info);
27
        $this->assertArrayHasKey('desc', $info);
28
        $this->assertArrayHasKey('url', $info);
29
30
        $this->assertEquals('issuelinks', $info['base']);
31
        $this->assertRegExp('/^https?:\/\//', $info['url']);
32
        $this->assertTrue(mail_isvalid($info['email']));
33
        $this->assertRegExp('/^\d\d\d\d-\d\d-\d\d$/', $info['date']);
34
        $this->assertTrue(false !== strtotime($info['date']));
35
    }
36
37
    /**
38
     * Test to ensure that every conf['...'] entry in conf/default.php has a corresponding meta['...'] entry in
39
     * conf/metadata.php.
40
     */
41
    public function test_plugin_conf()
42
    {
43
        $conf_file = __DIR__ . '/../conf/default.php';
44
        if (file_exists($conf_file)) {
45
            include($conf_file);
46
        }
47
        $meta_file = __DIR__ . '/../conf/metadata.php';
48
        if (file_exists($meta_file)) {
49
            include($meta_file);
50
        }
51
52
        $this->assertEquals(gettype($conf), gettype($meta),
0 ignored issues
show
Comprehensibility Best Practice introduced by
The variable $conf seems to be never defined.
Loading history...
Comprehensibility Best Practice introduced by
The variable $meta seems to be never defined.
Loading history...
53
            'Both ' . DOKU_PLUGIN . 'issuelinks/conf/default.php and ' . DOKU_PLUGIN . 'issuelinks/conf/metadata.php have to exist and contain the same keys.');
54
55
        if (gettype($conf) != 'NULL' && gettype($meta) != 'NULL') {
56
            foreach ($conf as $key => $value) {
57
                $this->assertArrayHasKey($key, $meta,
58
                    'Key $meta[\'' . $key . '\'] missing in ' . DOKU_PLUGIN . 'issuelinks/conf/metadata.php');
59
            }
60
61
            foreach ($meta as $key => $value) {
62
                $this->assertArrayHasKey($key, $conf,
63
                    'Key $conf[\'' . $key . '\'] missing in ' . DOKU_PLUGIN . 'issuelinks/conf/default.php');
64
            }
65
        }
66
67
    }
68
}
69