mirror of
https://gerrit.wikimedia.org/r/mediawiki/extensions/VisualEditor
synced 2025-01-08 11:14:25 +00:00
72b4f8cdbb
* Rename imported classes in VE that will be renamed in core * Re-enable tests that would fail when the core patch is merged Depends-On: I506f3303ae8f9e4db17299211366bef1558f142c Change-Id: I59ebeb24fa0de5f10d1501cc0830c7e4805e1003
143 lines
3.5 KiB
PHP
143 lines
3.5 KiB
PHP
<?php
|
|
|
|
namespace MediaWiki\Extension\VisualEditor\Tests;
|
|
|
|
use ApiTestCase;
|
|
use ExtensionRegistry;
|
|
use HashConfig;
|
|
use MediaWiki\Extension\VisualEditor\ApiVisualEditor;
|
|
use Wikimedia\ScopedCallback;
|
|
|
|
/**
|
|
* @group medium
|
|
* @group Database
|
|
*
|
|
* @covers \MediaWiki\Extension\VisualEditor\ApiVisualEditor
|
|
*/
|
|
class ApiVisualEditorTest extends ApiTestCase {
|
|
|
|
/** @var ScopedCallback|null */
|
|
private $scopedCallback;
|
|
|
|
/** @var @inheritDoc */
|
|
protected $tablesUsed = [ 'page', 'revision' ];
|
|
|
|
protected function setUp(): void {
|
|
parent::setUp();
|
|
$this->scopedCallback = ExtensionRegistry::getInstance()->setAttributeForTest(
|
|
'VisualEditorAvailableNamespaces',
|
|
[ 'User' => true, 'Template_Talk' => true ]
|
|
);
|
|
}
|
|
|
|
protected function tearDown(): void {
|
|
$this->scopedCallback = null;
|
|
parent::tearDown();
|
|
}
|
|
|
|
private function loadEditor( $overrideParams = [] ) {
|
|
$params = array_merge( [
|
|
'action' => 'visualeditor',
|
|
'paction' => 'metadata',
|
|
'page' => 'SomeTestPage',
|
|
], $overrideParams );
|
|
return $this->doApiRequestWithToken( $params );
|
|
}
|
|
|
|
public function testLoadEditorBasic() {
|
|
$data = $this->loadEditor()[0]['visualeditor'];
|
|
|
|
$this->assertSame( 'success', $data['result'] );
|
|
|
|
$properties = [
|
|
// When updating this, also update the sample response in
|
|
// ve.init.mw.DesktopArticleTarget.test.js
|
|
'result',
|
|
'notices',
|
|
'copyrightWarning',
|
|
'checkboxesDef',
|
|
'checkboxesMessages',
|
|
'protectedClasses',
|
|
'basetimestamp',
|
|
'starttimestamp',
|
|
'oldid',
|
|
'blockinfo',
|
|
'canEdit',
|
|
'content',
|
|
// When updating this, also update the sample response in
|
|
// ve.init.mw.DesktopArticleTarget.test.js
|
|
];
|
|
foreach ( $properties as $prop ) {
|
|
$this->assertArrayHasKey( $prop, $data, "Result has key '$prop'" );
|
|
}
|
|
|
|
$this->assertSameSize( $properties, $data, "No other properties are expected" );
|
|
}
|
|
|
|
/**
|
|
* @dataProvider provideLoadEditorPreload
|
|
*/
|
|
public function testLoadEditorPreload( $params, $expected ) {
|
|
$this->assertSame(
|
|
$expected,
|
|
$this->loadEditor( $params )[0]['visualeditor']['content']
|
|
);
|
|
}
|
|
|
|
public function provideLoadEditorPreload() {
|
|
return [
|
|
'load with preload content' => [
|
|
[
|
|
'preload' => 'UTPage',
|
|
'paction' => 'wikitext',
|
|
],
|
|
'UTContent',
|
|
],
|
|
'load with preload via Special:MyLanguage' => [
|
|
// NB UTPage isn't actually translated, so we get the same content back.
|
|
[
|
|
'preload' => 'Special:MyLanguage/UTPage',
|
|
'paction' => 'wikitext',
|
|
],
|
|
'UTContent',
|
|
]
|
|
];
|
|
}
|
|
|
|
public function testIsAllowedNamespace() {
|
|
$config = new HashConfig( [ 'VisualEditorAvailableNamespaces' => [
|
|
0 => true,
|
|
1 => false,
|
|
] ] );
|
|
$this->assertTrue( ApiVisualEditor::isAllowedNamespace( $config, 0 ) );
|
|
$this->assertFalse( ApiVisualEditor::isAllowedNamespace( $config, 1 ) );
|
|
}
|
|
|
|
public function testGetAvailableNamespaceIds() {
|
|
$config = new HashConfig( [ 'VisualEditorAvailableNamespaces' => [
|
|
0 => true,
|
|
1 => false,
|
|
-1 => true,
|
|
999999 => true,
|
|
2 => false,
|
|
'Template' => true,
|
|
'Foobar' => true,
|
|
] ] );
|
|
$this->assertSame(
|
|
[ -1, 0, 10, 11 ],
|
|
ApiVisualEditor::getAvailableNamespaceIds( $config )
|
|
);
|
|
}
|
|
|
|
public function testIsAllowedContentType() {
|
|
$config = new HashConfig( [ 'VisualEditorAvailableContentModels' => [
|
|
'on' => true,
|
|
'off' => false,
|
|
] ] );
|
|
$this->assertTrue( ApiVisualEditor::isAllowedContentType( $config, 'on' ) );
|
|
$this->assertFalse( ApiVisualEditor::isAllowedContentType( $config, 'off' ) );
|
|
$this->assertFalse( ApiVisualEditor::isAllowedContentType( $config, 'unknown' ) );
|
|
}
|
|
|
|
}
|