mirror of
https://gerrit.wikimedia.org/r/mediawiki/extensions/Echo
synced 2024-12-11 07:26:29 +00:00
3a7e655229
* Clear echo_event before the test. Otherwise it contains a 'thank-you-edit' event that offsets everything. * Use standard $this->db * Use standard ~~~~ signature Bug: T67336 Change-Id: Idd09aa107d01038d03b689d9086f65a9fb7b653a
79 lines
2.6 KiB
PHP
79 lines
2.6 KiB
PHP
<?php
|
|
|
|
/**
|
|
* @group Echo
|
|
* @group Database
|
|
* @group medium
|
|
*/
|
|
class EchoTalkPageFunctionalTest extends ApiTestCase {
|
|
|
|
protected function setUp() {
|
|
parent::setUp();
|
|
$this->db->delete( 'echo_event', '*' );
|
|
}
|
|
|
|
/**
|
|
* Creates and updates a user talk page a few times to ensure proper events are
|
|
* created. The user performing the edits is self::$users['sysop'].
|
|
* @covers \EchoDiscussionParser
|
|
*/
|
|
public function testAddCommentsToTalkPage() {
|
|
$talkPage = self::$users['uploader']->getUser()->getName();
|
|
|
|
$messageCount = 0;
|
|
$this->assertCount( $messageCount, $this->fetchAllEvents() );
|
|
|
|
// Start a talkpage
|
|
$content = "== Section 8 ==\n\nblah blah ~~~~\n";
|
|
$this->editPage( $talkPage, $content, '', NS_USER_TALK );
|
|
|
|
// Ensure the proper event was created
|
|
$events = $this->fetchAllEvents();
|
|
$this->assertCount( 1 + $messageCount, $events, 'After initial edit a single event must exist.' ); // +1 is due to 0 index
|
|
$row = array_shift( $events );
|
|
$this->assertEquals( 'edit-user-talk', $row->event_type );
|
|
$this->assertEventSectionTitle( 'Section 8', $row );
|
|
|
|
// Add another message to the talk page
|
|
$messageCount++;
|
|
$content .= "More content ~~~~\n";
|
|
$this->editPage( $talkPage, $content, '', NS_USER_TALK );
|
|
|
|
// Ensure another event was created
|
|
$events = $this->fetchAllEvents();
|
|
$this->assertCount( 1 + $messageCount, $events );
|
|
$row = array_shift( $events );
|
|
$this->assertEquals( 'edit-user-talk', $row->event_type );
|
|
$this->assertEventSectionTitle( 'Section 8', $row );
|
|
|
|
// Add a new section and a message within it
|
|
$messageCount++;
|
|
$content .= "\n\n== EE ==\n\nhere we go with a new section ~~~~\n";
|
|
$this->editPage( $talkPage, $content, '', NS_USER_TALK );
|
|
|
|
// Ensure this event has the new section title
|
|
$events = $this->fetchAllEvents();
|
|
$this->assertCount( 1 + $messageCount, $events );
|
|
$row = array_pop( $events );
|
|
$this->assertEquals( 'edit-user-talk', $row->event_type );
|
|
$this->assertEventSectionTitle( 'EE', $row );
|
|
}
|
|
|
|
protected function assertEventSectionTitle( $sectionTitle, $row ) {
|
|
$this->assertNotNull( $row->event_extra, 'Event must contain extra data.' );
|
|
$extra = unserialize( $row->event_extra );
|
|
$this->assertArrayHasKey( 'section-title', $extra, 'Extra data must include a section-title key.' );
|
|
$this->assertEquals( $sectionTitle, $extra['section-title'], 'Detected section title must match' );
|
|
}
|
|
|
|
/**
|
|
* @return \stdClass[] All events in db sorted from oldest to newest
|
|
*/
|
|
protected function fetchAllEvents() {
|
|
$res = $this->db->select( 'echo_event', EchoEvent::selectFields(), [], __METHOD__, [ 'ORDER BY' => 'event_id ASC' ] );
|
|
|
|
return iterator_to_array( $res );
|
|
}
|
|
|
|
}
|