Merge "Add tests for WikiMap and WikiReference"
[lhc/web/wiklou.git] / tests / phpunit / includes / WikiReferenceTest.php
1 <?php
2
3 /**
4 * @covers WikiReference
5 */
6
7 class WikiReferenceTest extends PHPUnit_Framework_TestCase {
8
9 public function provideGetHostname() {
10 return array(
11 'http' => array( 'foo.bar', 'http://foo.bar' ),
12 'https' => array( 'foo.bar', 'https://foo.bar' ),
13 );
14 }
15
16 /**
17 * @dataProvider provideGetHostname
18 */
19 public function testGetHostname( $expected, $canonicalServer ) {
20 $this->markTestSkipped( 'The implementation is patently broken.' );
21
22 $reference = new WikiReference( 'wiki', 'xx', $canonicalServer, '/wiki/$1' );
23 $this->assertEquals( $expected, $reference->getHostname() );
24 }
25
26 public function provideGetDisplayName() {
27 return array(
28 'http' => array( 'foo.bar', 'http://foo.bar' ),
29 'https' => array( 'foo.bar', 'http://foo.bar' ),
30
31 // apparently, this is the expected behavior
32 'invalid' => array( 'purple kittens/wiki/', 'purple kittens' ),
33 );
34 }
35
36 /**
37 * @dataProvider provideGetDisplayName
38 */
39 public function testGetDisplayName( $expected, $canonicalServer ) {
40 $reference = new WikiReference( 'wiki', 'xx', $canonicalServer, '/wiki/$1' );
41 $this->assertEquals( $expected, $reference->getDisplayName() );
42 }
43
44 public function testGetCanonicalServer() {
45 $reference = new WikiReference( 'wiki', 'xx', 'https://acme.com', '/wiki/$1', '//acme.com' );
46 $this->assertEquals( 'https://acme.com', $reference->getCanonicalServer() );
47 }
48
49 public function provideGetCanonicalUrl() {
50 return array(
51 'wiki path' => array( 'https://acme.com/wiki/Foo', 'https://acme.com', '//acme.com', '/wiki/$1', 'Foo' ),
52 'empty path' => array( 'https://acme.com/Foo', 'https://acme.com', '//acme.com', '/$1', 'Foo' ),
53 );
54 }
55
56 /**
57 * @dataProvider provideGetCanonicalUrl
58 */
59 public function testGetCanonicalUrl( $expected, $canonicalServer, $server, $path, $page ) {
60 $reference = new WikiReference( 'wiki', 'xx', $canonicalServer, $path, $server );
61 $this->assertEquals( $expected, $reference->getCanonicalUrl( $page ) );
62 }
63
64 /**
65 * @dataProvider provideGetCanonicalUrl
66 */
67 public function testGetUrl( $expected, $canonicalServer, $server, $path, $page ) {
68 $reference = new WikiReference( 'wiki', 'xx', $canonicalServer, $path, $server );
69 $this->assertEquals( $expected, $reference->getUrl( $page ) );
70 }
71
72 public function provideGetFullUrl() {
73 return array(
74 'wiki path' => array( '//acme.com/wiki/Foo', 'https://acme.com', '//acme.com', '/wiki/$1', 'Foo', null ),
75 'empty path' => array( '//acme.com/Foo', 'https://acme.com', '//acme.com', '/$1', 'Foo', null ),
76 );
77 }
78
79 /**
80 * @dataProvider provideGetFullUrl
81 */
82 public function testGetFullUrl( $expected, $canonicalServer, $server, $path, $page ) {
83 $reference = new WikiReference( 'wiki', 'xx', $canonicalServer, $path, $server );
84 $this->assertEquals( $expected, $reference->getFullUrl( $page ) );
85 }
86
87 }
88