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
92
93
94
|
<?php
/**
* @covers \MergeLogFormatter
*/
class MergeLogFormatterTest extends LogFormatterTestCase {
/**
* Provide different rows from the logging table to test
* for backward compatibility.
* Do not change the existing data, just add a new database row
*/
public static function provideMergeLogDatabaseRows() {
return [
// Current format with a revid
[
[
'type' => 'merge',
'action' => 'merge',
'comment' => 'Merge comment',
'namespace' => NS_MAIN,
'title' => 'OldPage',
'params' => [
'4::dest' => 'NewPage',
'5::mergepoint' => '20140804160710',
'6::mergerevid' => '1234'
],
],
[
'text' => 'User merged OldPage into NewPage (revisions up to 16:07, 4 August 2014)',
'api' => [
'mergerevid' => '1234',
'dest_ns' => 0,
'dest_title' => 'NewPage',
'mergepoint' => '2014-08-04T16:07:10Z',
],
],
],
// Same format without a revid
[
[
'type' => 'merge',
'action' => 'merge',
'comment' => 'Merge comment',
'namespace' => NS_MAIN,
'title' => 'OldPage',
'params' => [
'4::dest' => 'NewPage',
'5::mergepoint' => '20140804160710',
],
],
[
'text' => 'User merged OldPage into NewPage (revisions up to 16:07, 4 August 2014)',
'api' => [
'dest_ns' => 0,
'dest_title' => 'NewPage',
'mergepoint' => '2014-08-04T16:07:10Z',
],
],
],
// Legacy format
[
[
'type' => 'merge',
'action' => 'merge',
'comment' => 'merge comment',
'namespace' => NS_MAIN,
'title' => 'OldPage',
'params' => [
'NewPage',
'20140804160710',
],
],
[
'legacy' => true,
'text' => 'User merged OldPage into NewPage (revisions up to 16:07, 4 August 2014)',
'api' => [
'dest_ns' => 0,
'dest_title' => 'NewPage',
'mergepoint' => '2014-08-04T16:07:10Z',
],
],
],
];
}
/**
* @dataProvider provideMergeLogDatabaseRows
*/
public function testMergeLogDatabaseRows( $row, $extra ) {
$this->doTestLogFormatter( $row, $extra );
}
}
|