mirror of
https://gerrit.wikimedia.org/r/mediawiki/extensions/Cite
synced 2025-01-05 10:15:05 +00:00
ad56220cc4
This is just a minor optimization. The keys should now all follow the schema for Reference Previews in this extension. I'm not touching the `popups-prefs-conflicting-gadgets-info` key. That one was not copied over to this codebase and IMO we could really remove it for the reasons in that comment. Bug: T355194 Change-Id: I1948cf0aaca4d0ab3676bac806c7287568db8712
156 lines
4.7 KiB
PHP
156 lines
4.7 KiB
PHP
<?php
|
|
|
|
namespace Cite\Tests;
|
|
|
|
use Cite\Hooks\CiteHooks;
|
|
use Cite\ReferencePreviews\ReferencePreviewsGadgetsIntegration;
|
|
use MediaWiki\Api\ApiQuerySiteinfo;
|
|
use MediaWiki\Config\HashConfig;
|
|
use MediaWiki\ResourceLoader\ResourceLoader;
|
|
use MediaWiki\User\Options\StaticUserOptionsLookup;
|
|
use MediaWiki\User\User;
|
|
|
|
/**
|
|
* @covers \Cite\Hooks\CiteHooks
|
|
* @license GPL-2.0-or-later
|
|
*/
|
|
class CiteHooksTest extends \MediaWikiIntegrationTestCase {
|
|
|
|
/**
|
|
* @dataProvider provideBooleans
|
|
*/
|
|
public function testOnResourceLoaderGetConfigVars( bool $enabled ) {
|
|
$vars = [];
|
|
|
|
$config = new HashConfig( [
|
|
'CiteVisualEditorOtherGroup' => $enabled,
|
|
'CiteResponsiveReferences' => $enabled,
|
|
'CiteBookReferencing' => $enabled,
|
|
] );
|
|
|
|
( new CiteHooks(
|
|
$this->getServiceContainer()->getService( 'Cite.ReferencePreviewsContext' ),
|
|
$this->getServiceContainer()->getService( 'Cite.GadgetsIntegration' ),
|
|
new StaticUserOptionsLookup( [] )
|
|
) )
|
|
->onResourceLoaderGetConfigVars( $vars, 'vector', $config );
|
|
|
|
$this->assertSame( [
|
|
'wgCiteVisualEditorOtherGroup' => $enabled,
|
|
'wgCiteResponsiveReferences' => $enabled,
|
|
'wgCiteBookReferencing' => $enabled,
|
|
], $vars );
|
|
}
|
|
|
|
/**
|
|
* @dataProvider provideBooleans
|
|
*/
|
|
public function testOnResourceLoaderRegisterModules( bool $enabled ) {
|
|
$this->markTestSkippedIfExtensionNotLoaded( 'Popups' );
|
|
|
|
$resourceLoader = $this->createMock( ResourceLoader::class );
|
|
$resourceLoader->method( 'getConfig' )
|
|
->willReturn( new HashConfig( [ 'CiteReferencePreviews' => $enabled ] ) );
|
|
$resourceLoader->expects( $this->exactly( (int)$enabled ) )
|
|
->method( 'register' );
|
|
|
|
( new CiteHooks(
|
|
$this->getServiceContainer()->getService( 'Cite.ReferencePreviewsContext' ),
|
|
$this->getServiceContainer()->getService( 'Cite.GadgetsIntegration' ),
|
|
new StaticUserOptionsLookup( [] )
|
|
) )
|
|
->onResourceLoaderRegisterModules( $resourceLoader );
|
|
}
|
|
|
|
/**
|
|
* @dataProvider provideBooleans
|
|
*/
|
|
public function testOnAPIQuerySiteInfoGeneralInfo( bool $enabled ) {
|
|
$api = $this->createMock( ApiQuerySiteinfo::class );
|
|
$api->expects( $this->once() )
|
|
->method( 'getConfig' )
|
|
->willReturn( new HashConfig( [ 'CiteResponsiveReferences' => $enabled ] ) );
|
|
|
|
$data = [];
|
|
|
|
( new CiteHooks(
|
|
$this->getServiceContainer()->getService( 'Cite.ReferencePreviewsContext' ),
|
|
$this->getServiceContainer()->getService( 'Cite.GadgetsIntegration' ),
|
|
new StaticUserOptionsLookup( [] )
|
|
) )
|
|
->onAPIQuerySiteInfoGeneralInfo( $api, $data );
|
|
|
|
$this->assertSame( [ 'citeresponsivereferences' => $enabled ], $data );
|
|
}
|
|
|
|
public static function provideBooleans() {
|
|
yield [ true ];
|
|
yield [ false ];
|
|
}
|
|
|
|
public function testOnGetPreferences_noConflicts() {
|
|
$expected = [
|
|
'popups-reference-previews' => [
|
|
'type' => 'toggle',
|
|
'label-message' => 'cite-reference-previews-preference-label',
|
|
'help-message' => 'popups-prefs-conflicting-gadgets-info',
|
|
'section' => 'rendering/reading'
|
|
]
|
|
];
|
|
$gadgetsIntegrationMock = $this->createMock( ReferencePreviewsGadgetsIntegration::class );
|
|
$prefs = [];
|
|
( new CiteHooks(
|
|
$this->getServiceContainer()->getService( 'Cite.ReferencePreviewsContext' ),
|
|
$gadgetsIntegrationMock,
|
|
new StaticUserOptionsLookup( [] )
|
|
) )
|
|
->onGetPreferences( $this->createMock( User::class ), $prefs );
|
|
$this->assertEquals( $expected, $prefs );
|
|
}
|
|
|
|
public function testOnGetPreferences_conflictingGadget() {
|
|
$expected = [
|
|
'popups-reference-previews' => [
|
|
'type' => 'toggle',
|
|
'label-message' => 'cite-reference-previews-preference-label',
|
|
'help-message' => [
|
|
'cite-reference-previews-gadget-conflict-info-navpopups',
|
|
'Special:Preferences#mw-prefsection-gadgets',
|
|
],
|
|
'section' => 'rendering/reading',
|
|
'disabled' => true
|
|
]
|
|
];
|
|
$gadgetsIntegrationMock = $this->createMock( ReferencePreviewsGadgetsIntegration::class );
|
|
$gadgetsIntegrationMock->expects( $this->once() )
|
|
->method( 'isNavPopupsGadgetEnabled' )
|
|
->willReturn( true );
|
|
$prefs = [];
|
|
( new CiteHooks(
|
|
$this->getServiceContainer()->getService( 'Cite.ReferencePreviewsContext' ),
|
|
$gadgetsIntegrationMock,
|
|
new StaticUserOptionsLookup( [] )
|
|
) )
|
|
->onGetPreferences( $this->createMock( User::class ), $prefs );
|
|
$this->assertEquals( $expected, $prefs );
|
|
}
|
|
|
|
public function testOnGetPreferences_redundantPreference() {
|
|
$prefs = [
|
|
'popups-reference-previews' => [
|
|
'type' => 'toggle',
|
|
'label-message' => 'from-another-extension',
|
|
]
|
|
];
|
|
$expected = $prefs;
|
|
( new CiteHooks(
|
|
$this->getServiceContainer()->getService( 'Cite.ReferencePreviewsContext' ),
|
|
$this->getServiceContainer()->getService( 'Cite.GadgetsIntegration' ),
|
|
new StaticUserOptionsLookup( [] )
|
|
) )
|
|
->onGetPreferences( $this->createMock( User::class ), $prefs );
|
|
$this->assertEquals( $expected, $prefs );
|
|
}
|
|
|
|
}
|