1<?php
2/*
3 * Copyright (c) 2016 Mark C. Prins <mprins@users.sf.net>
4 *
5 * Permission to use, copy, modify, and distribute this software for any
6 * purpose with or without fee is hereby granted, provided that the above
7 * copyright notice and this permission notice appear in all copies.
8 *
9 * THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES
10 * WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF
11 * MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR
12 * ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES
13 * WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN
14 * ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF
15 * OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
16 */
17
18/**
19 * Syntax tests for the backlinks plugin.
20 *
21 * @group plugin_backlinks
22 * @group plugins
23 */
24class syntax_include_plugin_backlinks_test extends DokuWikiTest {
25
26    protected $pluginsEnabled = array('backlinks');
27
28    /**
29     * copy data.
30     */
31    public static function setUpBeforeClass() {
32        parent::setUpBeforeClass();
33        global $conf;
34        $conf['allowdebug'] = 1;
35
36        TestUtils::rcopy(TMP_DIR, dirname(__FILE__).'/data/');
37
38        dbglog("\nset up class syntax_plugin_backlinks_test");
39    }
40
41    function setUp() {
42        parent::setUp();
43
44        global $conf;
45        $conf['allowdebug'] = 1;
46        $conf['cachetime'] = -1;
47
48        $data = array();
49        search($data, $conf['datadir'], 'search_allpages', array('skipacl' => true));
50
51        //dbglog($data, "pages for indexing");
52
53        $verbose = false;
54        $force = false;
55        foreach ($data as $val) {
56            idx_addPage($val['id'], $verbose, $force);
57        }
58
59        if ($conf['allowdebug']) {
60            touch(DOKU_TMP_DATA.'cache/debug.log');
61        }
62    }
63
64    public function tearDown() {
65        parent::tearDown();
66
67        global $conf;
68        // try to get the debug log after running the test, print and clear
69        if ($conf['allowdebug']) {
70            print "\n";
71            readfile(DOKU_TMP_DATA.'cache/debug.log');
72            unlink(DOKU_TMP_DATA.'cache/debug.log');
73        }
74    }
75
76    public function testInclude() {
77        $request = new TestRequest();
78        $response = $request->get(array('id'=>'backlinks_include_syntax'), '/doku.php');
79
80        $this->assertTrue(
81            strpos($response->getContent(), 'Backlinks to what Bob Ross says (including only)') !== false,
82            '"Backlinks to what Bob Ross says (including only)" was not in the output'
83        );
84
85        $doc = phpQuery::newDocument($response->getContent());
86        // look for id="plugin__backlinks"
87        $this->assertEquals(
88                            1,
89                            pq('#plugin__backlinks', $doc)->length,
90                            'There should be one backlinks element'
91                           );
92
93        $wikilinks = pq('#plugin__backlinks ul li', $doc);
94        dbglog($wikilinks->text(), 'found backlinks');
95        $this->assertEquals(
96                            1,
97                            $wikilinks->contents()->length,
98                            'There should be 1 backlink'
99                           );
100
101        $lastlink = pq('a:last', $wikilinks);
102        dbglog($lastlink->text(), "last backlink");
103        $this->assertEquals(
104                            $lastlink->text(),
105                            'An included link to Bob Ross',
106                            'The last backlink should be "An included link to Bob Ross"'
107                           );
108    }
109}
110