mirror of
https://github.com/StarCitizenTools/mediawiki-skins-Citizen.git
synced 2025-01-19 08:25:54 +00:00
99 lines
2.4 KiB
PHP
99 lines
2.4 KiB
PHP
|
<?php
|
||
|
|
||
|
declare( strict_types=1 );
|
||
|
|
||
|
namespace MediaWiki\Skins\Citizen\Tests\Unit\Components;
|
||
|
|
||
|
use MediaWiki\Skins\Citizen\Components\CitizenComponent;
|
||
|
use MediaWiki\Skins\Citizen\Components\CitizenComponentMenu;
|
||
|
use MediaWikiUnitTestCase;
|
||
|
|
||
|
/**
|
||
|
* @group Citizen
|
||
|
* @group Components
|
||
|
* @coversDefaultClass \MediaWiki\Skins\Citizen\Components\CitizenComponentMenu
|
||
|
*/
|
||
|
class CitizenComponentMenuTest extends MediaWikiUnitTestCase {
|
||
|
|
||
|
/**
|
||
|
* @return array[]
|
||
|
*/
|
||
|
public function provideMenuData(): array {
|
||
|
return [
|
||
|
[
|
||
|
[
|
||
|
'class' => 'some-class',
|
||
|
'label' => 'Some label',
|
||
|
'html-tooltip' => 'Some tooltip',
|
||
|
'label-class' => 'some-label-class',
|
||
|
'html-before-portal' => 'Some before portal',
|
||
|
'html-items' => 'Some items',
|
||
|
'html-after-portal' => 'Some after portal',
|
||
|
'array-list-items' => [ 'some-item-one', 'some-item-2', 'some-item-3' ]
|
||
|
]
|
||
|
]
|
||
|
];
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* @return array[]
|
||
|
*/
|
||
|
public function provideCountData(): array {
|
||
|
return [
|
||
|
[
|
||
|
[
|
||
|
'array-list-items' => [ 'some-item-one', 'some-item-2', 'some-item-3' ]
|
||
|
],
|
||
|
3
|
||
|
],
|
||
|
[
|
||
|
[
|
||
|
'html-items' => '<li>Some item</li><li>Some item</li><li>Some item</li>'
|
||
|
],
|
||
|
3
|
||
|
]
|
||
|
];
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* This test checks if the CitizenComponentMenu class can be instantiated
|
||
|
* @covers ::__construct
|
||
|
*/
|
||
|
public function testConstruct() {
|
||
|
// Create a new CitizenComponentMenu object
|
||
|
$menu = new CitizenComponentMenu( [] );
|
||
|
|
||
|
// Check if the object is an instance of CitizenComponent
|
||
|
$this->assertInstanceOf( CitizenComponent::class, $menu );
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* This test checks if the count method returns the correct number of items
|
||
|
* @covers ::count
|
||
|
* @dataProvider provideCountData
|
||
|
*/
|
||
|
public function testCount( array $data, int $expected ) {
|
||
|
// Create a new CitizenComponentMenu object
|
||
|
$menu = new CitizenComponentMenu( $data );
|
||
|
|
||
|
// Check if the count method returns the correct number of items
|
||
|
$this->assertSame( $expected, $menu->count() );
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* This test checks if the getTemplateData method returns the correct data
|
||
|
* @covers ::getTemplateData
|
||
|
* @dataProvider provideMenuData
|
||
|
*/
|
||
|
public function testGetTemplateData( array $data ) {
|
||
|
// Create a new CitizenComponentMenu object
|
||
|
$menu = new CitizenComponentMenu( $data );
|
||
|
|
||
|
// Call the getTemplateData method
|
||
|
$actualData = $menu->getTemplateData();
|
||
|
|
||
|
// Check if the getTemplateData method returns the correct data
|
||
|
$this->assertSame( $data, $actualData );
|
||
|
}
|
||
|
}
|