1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
|
<?php
use MediaWiki\Content\CssContent;
use MediaWiki\Content\JsonContent;
use MediaWiki\Content\TextContent;
use MediaWiki\Content\WikitextContent;
use Wikimedia\Assert\ParameterTypeException;
use Wikimedia\TestingAccessWrapper;
/**
* @covers \SlotDiffRenderer
*/
class SlotDiffRendererTest extends \MediaWikiIntegrationTestCase {
/**
* @dataProvider provideNormalizeContents
*/
public function testNormalizeContents(
$oldContent, $newContent, $allowedClasses,
$expectedOldContent, $expectedNewContent, $expectedExceptionClass
) {
$slotDiffRenderer = $this->createMock( SlotDiffRenderer::class );
try {
// __call needs help deciding which parameter to take by reference
call_user_func_array( [ TestingAccessWrapper::newFromObject( $slotDiffRenderer ),
'normalizeContents' ], [ &$oldContent, &$newContent, $allowedClasses ] );
$this->assertEquals( $expectedOldContent, $oldContent );
$this->assertEquals( $expectedNewContent, $newContent );
} catch ( Exception $e ) {
if ( !$expectedExceptionClass ) {
throw $e;
}
$this->assertInstanceOf( $expectedExceptionClass, $e );
}
}
public static function provideNormalizeContents() {
return [
'both null' => [ null, null, null, null, null, InvalidArgumentException::class ],
'left null' => [
null, new WikitextContent( 'abc' ), null,
new WikitextContent( '' ), new WikitextContent( 'abc' ), null,
],
'right null' => [
new WikitextContent( 'def' ), null, null,
new WikitextContent( 'def' ), new WikitextContent( '' ), null,
],
'type filter' => [
new WikitextContent( 'abc' ), new WikitextContent( 'def' ), WikitextContent::class,
new WikitextContent( 'abc' ), new WikitextContent( 'def' ), null,
],
'type filter (subclass)' => [
new WikitextContent( 'abc' ), new WikitextContent( 'def' ), TextContent::class,
new WikitextContent( 'abc' ), new WikitextContent( 'def' ), null,
],
'type filter (null)' => [
new WikitextContent( 'abc' ), null, TextContent::class,
new WikitextContent( 'abc' ), new WikitextContent( '' ), null,
],
'type filter failure (left)' => [
new TextContent( 'abc' ), new WikitextContent( 'def' ), WikitextContent::class,
// Throws incompatible exception because the right content matches the filter and the
// left doesn't. All other kinds of mismatches should result in a parameter type exception.
null, null, IncompatibleDiffTypesException::class,
],
'type filter failure (right)' => [
new WikitextContent( 'abc' ), new TextContent( 'def' ), WikitextContent::class,
null, null, ParameterTypeException::class,
],
'type filter failure (left, with null)' => [
new TextContent( 'abc' ), null, WikitextContent::class,
null, null, ParameterTypeException::class,
],
'type filter failure (right, with null)' => [
null, new TextContent( 'def' ), WikitextContent::class,
null, null, ParameterTypeException::class,
],
'type filter (array syntax)' => [
new WikitextContent( 'abc' ), new JsonContent( 'def' ),
[ JsonContent::class, WikitextContent::class ],
new WikitextContent( 'abc' ), new JsonContent( 'def' ), null,
],
'type filter failure (array syntax)' => [
new WikitextContent( 'abc' ), new CssContent( 'def' ),
[ JsonContent::class, WikitextContent::class ],
null, null, ParameterTypeException::class,
],
];
}
}
|