2015-04-27 14:05:31 +00:00
< ? php
class PortableInfoboxRenderServiceTest extends PHPUnit_Framework_TestCase {
private $infoboxRenderService ;
2015-05-04 14:43:53 +00:00
protected function setUp () {
$this -> setupFile = dirname ( __FILE__ ) . '/../PortableInfobox.setup.php' ;
2015-04-27 14:05:31 +00:00
parent :: setUp ();
2015-05-07 13:19:46 +00:00
$mock = $this -> getMock ( 'PortableInfoboxRenderService' , [ 'getThumbnailUrl' ] );
2015-05-07 13:01:48 +00:00
$mock -> expects ( $this -> any () ) -> method ( 'getThumbnailUrl' ) -> will ( $this -> returnValue ( 'http://image.jpg' ) );
2015-05-07 12:36:30 +00:00
$this -> infoboxRenderService = $mock ;
2015-04-27 14:05:31 +00:00
}
2015-07-01 14:34:34 +00:00
private function setWikiaMobileSkin ( $bool ) {
2015-05-20 11:56:56 +00:00
$this -> infoboxRenderService -> expects ( $this -> any () ) -> method ( 'isWikiaMobile' ) -> will ( $this -> returnValue
2015-07-01 14:34:34 +00:00
( $bool ) );
}
private function setInfoboxHeroEnabled ( $bool ) {
$this -> infoboxRenderService -> expects ( $this -> any () ) -> method ( 'isInfoboxHeroEnabled' ) -> will ( $this -> returnValue
( $bool ) );
2015-05-20 11:56:56 +00:00
}
2015-04-27 14:05:31 +00:00
/**
* @ param $input
* @ param $expectedOutput
* @ param $description
* @ dataProvider testRenderInfoboxDataProvider
*/
public function testRenderInfobox ( $input , $expectedOutput , $description ) {
2015-07-01 14:34:34 +00:00
$this -> setWikiaMobileSkin ( false );
$this -> setInfoboxHeroEnabled ( false );
2015-05-07 12:36:30 +00:00
2015-04-27 14:05:31 +00:00
$actualOutput = $this -> infoboxRenderService -> renderInfobox ( $input );
$actualDOM = new DOMDocument ( '1.0' );
$expectedDOM = new DOMDocument ( '1.0' );
$actualDOM -> formatOutput = true ;
$actualDOM -> preserveWhiteSpace = false ;
$expectedDOM -> formatOutput = true ;
$expectedDOM -> preserveWhiteSpace = false ;
$actualDOM -> loadXML ( $actualOutput );
$expectedDOM -> loadXML ( $expectedOutput );
2015-05-04 14:56:39 +00:00
$expectedHtml = $expectedDOM -> saveXML ();
$actualHtml = $actualDOM -> saveXML ();
2015-05-04 14:16:35 +00:00
$this -> assertEquals ( $expectedHtml , $actualHtml , $description );
2015-04-27 14:05:31 +00:00
}
2015-05-20 11:56:56 +00:00
/**
* @ param $input
* @ param $expectedOutput
* @ param $description
2015-07-01 14:34:34 +00:00
* @ dataProvider testRenderMobileInfoboxDataProvider
2015-05-20 11:56:56 +00:00
*/
public function testRenderMobileInfobox ( $input , $expectedOutput , $description ) {
2015-07-01 14:34:34 +00:00
$this -> setWikiaMobileSkin ( true );
$this -> setInfoboxHeroEnabled ( false );
$actualOutput = $this -> infoboxRenderService -> renderInfobox ( $input );
$actualDOM = new DOMDocument ( '1.0' );
$expectedDOM = new DOMDocument ( '1.0' );
$actualDOM -> formatOutput = true ;
$actualDOM -> preserveWhiteSpace = false ;
$expectedDOM -> formatOutput = true ;
$expectedDOM -> preserveWhiteSpace = false ;
$actualDOM -> loadXML ( $actualOutput );
$expectedDOM -> loadXML ( $expectedOutput );
$expectedHtml = $expectedDOM -> saveXML ();
$actualHtml = $actualDOM -> saveXML ();
$this -> assertEquals ( $expectedHtml , $actualHtml , $description );
}
/**
* @ param $input
* @ param $expectedOutput
* @ param $description
* @ dataProvider testRenderInfoboxWithHeroDataProvider
*/
public function testRenderInfoboxWithHero ( $input , $expectedOutput , $description ) {
$this -> setWikiaMobileSkin ( true );
$this -> setInfoboxHeroEnabled ( true );
2015-05-20 11:56:56 +00:00
$actualOutput = $this -> infoboxRenderService -> renderInfobox ( $input );
$actualDOM = new DOMDocument ( '1.0' );
$expectedDOM = new DOMDocument ( '1.0' );
$actualDOM -> formatOutput = true ;
$actualDOM -> preserveWhiteSpace = false ;
$expectedDOM -> formatOutput = true ;
$expectedDOM -> preserveWhiteSpace = false ;
$actualDOM -> loadXML ( $actualOutput );
$expectedDOM -> loadXML ( $expectedOutput );
$expectedHtml = $expectedDOM -> saveXML ();
$actualHtml = $actualDOM -> saveXML ();
$this -> assertEquals ( $expectedHtml , $actualHtml , $description );
}
2015-07-01 14:34:34 +00:00
public function testRenderInfoboxWithHeroDataProvider () {
return [
[
'input' => [
[
'type' => 'title' ,
'data' => [
'value' => 'Test Title'
]
],
[
'type' => 'image' ,
'data' => [
'alt' => 'image alt' ,
'caption' => 'image caption' ,
'value' => 'http://image.jpg'
]
],
[
'type' => 'data' ,
'data' => [
'label' => 'test label' ,
'value' => 'test value'
]
]
],
'output' => ' < aside class = " portable-infobox " >
< div class = " portable-infobox-item item-type-hero " >
< hgroup class = " portable-infobox-hero-title-wrapper portable-infobox-item-margins " >
< h2 class = " portable-infobox-hero-title " > Test Title </ h2 >
< h3 class = " portable-infobox-hero-caption " > image caption </ h3 >
</ hgroup >
< img src = " dta:image/gif;base64,R0lGODlhAQABAIABAAAAAP///yH5BAEAAAEALAAAAAABAAEAQAICTAEAOw%3D%3D " class = " portable-infobox-image lazy media article-media " alt = " image alt " data - image - key = " test1 " data - image - name = " test1 " data - ref = " 1 " data - src = " thumbnail.jpg " data - params = \ ' [{ " name " : " test1 " , " full " : " http://image.jpg " }] \ ' />
</ div >
< div class = " portable-infobox-item item-type-key-val portable-infobox-item-margins " >
< h3 class = " portable-infobox-item-label portable-infobox-header-font " > test label </ h3 >
< div class = " portable-infobox-item-value " > test value </ div >
</ div >
</ aside > ' ,
'description' => 'Simple infobox with title, image and key-value pair'
],
];
}
2015-04-27 14:05:31 +00:00
public function testRenderInfoboxDataProvider () {
return [
[
'input' => [],
'output' => '' ,
'description' => 'Empty data should yield no infobox markup'
],
[
'input' => [
[
'type' => 'title' ,
'data' => [
'value' => 'Test Title'
2015-05-07 13:25:26 +00:00
]
2015-04-27 14:05:31 +00:00
]
],
2015-05-20 11:56:24 +00:00
'output' => ' < aside class = " portable-infobox " >
2015-05-07 12:36:30 +00:00
< div class = " portable-infobox-item item-type-title portable-infobox-item-margins " >
< h2 class = " portable-infobox-title " > Test Title </ h2 >
</ div >
</ aside > ' ,
2015-04-27 14:05:31 +00:00
'description' => 'Only title'
],
2015-05-20 11:56:56 +00:00
[
'input' => [
[
'type' => 'image' ,
'data' => [
'alt' => 'image alt' ,
'url' => 'http://image.jpg' ,
'caption' => 'Lorem ipsum dolor'
]
]
],
'output' => ' < aside class = " portable-infobox " >
< div class = " portable-infobox-item item-type-image no-margins " >
2015-05-25 13:57:16 +00:00
< figure class = " portable-infobox-image-wrapper " >
2015-05-20 11:56:56 +00:00
< a href = " http://image.jpg " class = " image image-thumbnail " title = " image alt " >
< img src = " http://image.jpg " class = " portable-infobox-image " alt = " image alt " data - image - key = " " data - image - name = " " />
</ a >
< figcaption class = " portable-infobox-item-margins portable-infobox-image-caption " > Lorem ipsum dolor </ figcaption >
</ figure >
</ div >
</ aside > ' ,
2015-05-25 13:57:16 +00:00
'description' => 'Only image'
2015-05-20 11:56:56 +00:00
],
2015-05-04 14:16:35 +00:00
[
'input' => [
[
'type' => 'footer' ,
'data' => [
'value' => 'Footer value' ,
]
]
],
2015-05-20 11:56:24 +00:00
'output' => ' < aside class = " portable-infobox " >
2015-05-07 12:36:30 +00:00
< footer class = " portable-infobox-footer portable-infobox-item-margins portable-infobox-header-background portable-infobox-header-font " > Footer value </ footer >
</ aside > ' ,
2015-05-04 14:16:35 +00:00
'description' => 'Footer only'
],
2015-05-04 14:30:40 +00:00
[
'input' => [
[
2015-05-07 12:36:30 +00:00
'type' => 'data' ,
2015-05-04 14:30:40 +00:00
'data' => [
'label' => 'test label' ,
'value' => 'test value'
2015-05-07 13:25:26 +00:00
]
2015-05-04 14:30:40 +00:00
]
],
2015-05-20 11:56:24 +00:00
'output' => ' < aside class = " portable-infobox " >
2015-05-07 12:36:30 +00:00
< div class = " portable-infobox-item item-type-key-val portable-infobox-item-margins " >
< h3 class = " portable-infobox-item-label portable-infobox-header-font " > test label </ h3 >
< div class = " portable-infobox-item-value " > test value </ div >
</ div >
</ aside > ' ,
2015-05-04 14:30:40 +00:00
'description' => 'Only pair'
],
2015-04-27 14:05:31 +00:00
[
'input' => [
[
'type' => 'title' ,
'data' => [
'value' => 'Test Title'
2015-05-07 13:25:26 +00:00
]
2015-04-27 14:05:31 +00:00
],
[
'type' => 'image' ,
'data' => [
'alt' => 'image alt' ,
'value' => 'http://image.jpg'
2015-05-07 13:25:26 +00:00
]
2015-04-27 14:05:31 +00:00
],
[
2015-05-04 10:48:57 +00:00
'type' => 'data' ,
2015-04-27 14:05:31 +00:00
'data' => [
'label' => 'test label' ,
'value' => 'test value'
2015-05-07 13:25:26 +00:00
]
2015-04-27 14:05:31 +00:00
]
],
2015-05-20 11:56:24 +00:00
'output' => ' < aside class = " portable-infobox " >
2015-05-07 12:36:30 +00:00
< div class = " portable-infobox-item item-type-title portable-infobox-item-margins " >
< h2 class = " portable-infobox-title " > Test Title </ h2 >
</ div >
< div class = " portable-infobox-item item-type-image no-margins " >
2015-05-21 11:06:54 +00:00
< figure class = " portable-infobox-image-wrapper " >
2015-05-07 12:36:30 +00:00
< a href = " " class = " image image-thumbnail " title = " image alt " >
< img src = " http://image.jpg " class = " portable-infobox-image " alt = " image alt " data - image - key = " " data - image - name = " " />
</ a >
</ figure >
</ div >
< div class = " portable-infobox-item item-type-key-val portable-infobox-item-margins " >
< h3 class = " portable-infobox-item-label portable-infobox-header-font " > test label </ h3 >
< div class = " portable-infobox-item-value " > test value </ div >
</ div >
</ aside > ' ,
2015-04-27 14:05:31 +00:00
'description' => 'Simple infobox with title, image and key-value pair'
],
[
'input' => [
[
'type' => 'title' ,
'data' => [
'value' => 'Test Title'
2015-05-07 13:25:26 +00:00
]
2015-04-27 14:05:31 +00:00
],
[
2015-05-04 10:48:57 +00:00
'type' => 'data' ,
2015-04-27 14:05:31 +00:00
'data' => [
'label' => 'test label' ,
'value' => 'test value'
2015-05-07 13:25:26 +00:00
]
2015-04-27 14:05:31 +00:00
]
],
2015-05-20 11:56:24 +00:00
'output' => ' < aside class = " portable-infobox " >
2015-05-04 14:30:40 +00:00
< div class = " portable-infobox-item item-type-title portable-infobox-item-margins " >
< h2 class = " portable-infobox-title " > Test Title </ h2 >
</ div >
2015-05-07 12:36:30 +00:00
< div class = " portable-infobox-item item-type-key-val portable-infobox-item-margins " >
< h3 class = " portable-infobox-item-label portable-infobox-header-font " > test label </ h3 >
< div class = " portable-infobox-item-value " > test value </ div >
2015-05-04 14:30:40 +00:00
</ div >
</ aside > ' ,
2015-05-07 12:36:30 +00:00
'description' => 'Simple infobox with title, empty image and key-value pair'
2015-05-04 14:30:40 +00:00
],
[
'input' => [
[
'type' => 'title' ,
'data' => [
'value' => 'Test Title'
2015-05-07 13:25:26 +00:00
]
2015-05-04 14:30:40 +00:00
],
[
'type' => 'group' ,
'data' => [
'value' => [
[
'type' => 'header' ,
'data' => [
'value' => 'Test Header'
2015-05-07 13:25:26 +00:00
]
2015-05-04 14:30:40 +00:00
],
[
2015-05-07 12:36:30 +00:00
'type' => 'data' ,
2015-05-04 14:30:40 +00:00
'data' => [
'label' => 'test label' ,
'value' => 'test value'
2015-05-07 13:25:26 +00:00
]
2015-05-04 14:30:40 +00:00
],
[
2015-05-07 12:36:30 +00:00
'type' => 'data' ,
2015-05-04 14:30:40 +00:00
'data' => [
'label' => 'test label' ,
'value' => 'test value'
2015-05-07 13:25:26 +00:00
]
2015-05-04 14:30:40 +00:00
]
]
2015-05-07 13:25:26 +00:00
]
2015-05-04 14:30:40 +00:00
]
],
2015-05-20 11:56:24 +00:00
'output' => ' < aside class = " portable-infobox " >
2015-05-04 14:30:40 +00:00
< div class = " portable-infobox-item item-type-title portable-infobox-item-margins " >
< h2 class = " portable-infobox-title " > Test Title </ h2 >
</ div >
< section class = " portable-infobox-item item-type-group " >
< div class = " portable-infobox-item item-type-header portable-infobox-item-margins portable-infobox-header-background " >
< h2 class = " portable-infobox-header portable-infobox-header-font " > Test Header </ h2 >
</ div >
< div class = " portable-infobox-item item-type-key-val portable-infobox-item-margins " >
< h3 class = " portable-infobox-item-label portable-infobox-header-font " > test label </ h3 >
< div class = " portable-infobox-item-value " > test value </ div >
</ div >
< div class = " portable-infobox-item item-type-key-val portable-infobox-item-margins " >
< h3 class = " portable-infobox-item-label portable-infobox-header-font " > test label </ h3 >
< div class = " portable-infobox-item-value " > test value </ div >
</ div >
</ section >
</ aside > ' ,
'description' => 'Infobox with title, image and group with header two key-value pairs'
],
2015-06-11 17:28:49 +00:00
[
'input' => [
[
'type' => 'group' ,
'data' => [
'value' => [
[
'type' => 'header' ,
'data' => [
'value' => 'Test Header'
]
],
[
'type' => 'data' ,
'data' => [
'label' => 'test label' ,
'value' => 'test value'
]
]
],
'layout' => 'horizontal'
]
]
],
'output' => ' < aside class = " portable-infobox " >
< section class = " portable-infobox-item item-type-group group-layout-horizontal " >
< div class = " portable-infobox-item item-type-header portable-infobox-item-margins portable-infobox-header-background " >
< h2 class = " portable-infobox-header portable-infobox-header-font " > Test Header </ h2 >
</ div >
< div class = " portable-infobox-item item-type-key-val portable-infobox-item-margins " >
< h3 class = " portable-infobox-item-label portable-infobox-header-font " > test label </ h3 >
< div class = " portable-infobox-item-value " > test value </ div >
</ div >
</ section >
</ aside > ' ,
'description' => 'Infobox with title, image and horizontal group'
],
2015-05-04 14:30:40 +00:00
[
'input' => [
[
'type' => 'comparison' ,
'data' => [
'value' => [
[
'type' => 'set' ,
'data' => [
'value' => [
[
'type' => 'header' ,
'data' => [
'value' => 'Test Header'
2015-05-07 13:25:26 +00:00
]
2015-05-04 14:30:40 +00:00
],
[
2015-05-07 12:36:30 +00:00
'type' => 'data' ,
2015-05-04 14:30:40 +00:00
'data' => [
'label' => 'test label' ,
'value' => 'test value'
2015-05-07 13:25:26 +00:00
]
2015-05-04 14:30:40 +00:00
],
[
2015-05-07 12:36:30 +00:00
'type' => 'data' ,
2015-05-04 14:30:40 +00:00
'data' => [
'label' => 'test label' ,
'value' => 'test value'
2015-05-07 13:25:26 +00:00
]
2015-05-04 14:30:40 +00:00
]
]
2015-05-07 13:25:26 +00:00
]
2015-05-04 14:30:40 +00:00
],
],
2015-05-07 13:25:26 +00:00
]
2015-05-04 14:30:40 +00:00
]
],
2015-05-20 11:56:24 +00:00
'output' => ' < aside class = " portable-infobox " >
2015-05-04 14:30:40 +00:00
< div class = " portable-infobox-item item-type-comparison " >
< table class = " portable-infobox-comparison " >
< tbody >
< tr class = " portable-infobox-comparison-set " >
< th class = " portable-infobox-comparison-set-header " >
< div class = " portable-infobox-item item-type-header portable-infobox-item-margins portable-infobox-header-background " >
< h2 class = " portable-infobox-header portable-infobox-header-font " > Test Header </ h2 >
</ div >
</ th >
< td class = " portable-infobox-comparison-item " >
< div class = " portable-infobox-item item-type-key-val portable-infobox-item-margins " >
< h3 class = " portable-infobox-item-label portable-infobox-header-font " > test label </ h3 >
< div class = " portable-infobox-item-value " > test value </ div >
</ div >
</ td >
< td class = " portable-infobox-comparison-item " >
< div class = " portable-infobox-item item-type-key-val portable-infobox-item-margins " >
< h3 class = " portable-infobox-item-label portable-infobox-header-font " > test label </ h3 >
< div class = " portable-infobox-item-value " > test value </ div >
</ div >
</ td >
</ tr >
</ tbody >
</ table >
</ div >
</ aside > ' ,
'description' => 'Infobox with comparison with two sets of which one is empty'
],
[
'input' => [
[
'type' => 'footer' ,
'data' => [
2015-05-07 12:36:30 +00:00
'value' => '<p>Links</p>'
2015-05-07 13:25:26 +00:00
]
2015-05-04 14:30:40 +00:00
]
],
2015-05-20 11:56:24 +00:00
'output' => ' < aside class = " portable-infobox " >
2015-05-07 12:36:30 +00:00
< footer class = " portable-infobox-footer portable-infobox-item-margins portable-infobox-header-background portable-infobox-header-font " >
2015-05-04 14:30:40 +00:00
< p > Links </ p >
</ footer >
</ aside > ' ,
'description' => 'Infobox with footer'
2015-04-27 14:05:31 +00:00
]
];
}
2015-05-20 11:56:56 +00:00
public function testRenderMobileInfoboxDataProvider () {
return [
[
'input' => [
[
'type' => 'image' ,
'data' => [
'alt' => 'image alt' ,
'url' => 'http://image.jpg' ,
'thumbnail' => 'thumbnail.jpg' ,
'ref' => 1 ,
'name' => 'test1'
]
]
],
'output' => ' < aside class = " portable-infobox " >
< div class = " portable-infobox-item item-type-image no-margins " >
< img src = " %3D%3D " class = " portable-infobox-image lazy media article-media " alt = " image alt " data - image - key = " test1 " data - image - name = " test1 " data - ref = " 1 " data - src = " thumbnail.jpg " data - params = \ ' [{ " name " : " test1 " , " full " : " http://image.jpg " }] \ ' />
</ div >
</ aside > ' ,
'description' => 'Only image for mobile'
]
];
}
2015-04-27 14:05:31 +00:00
}