mirror of
https://gerrit.wikimedia.org/r/mediawiki/extensions/Echo
synced 2024-12-21 12:12:57 +00:00
5611662f06
Depends-On: Id28792658de950b99a8786f881563476def59eba Change-Id: Ib57ea2db947285946f31fa9912b37181044df9d3
90 lines
1.8 KiB
PHP
90 lines
1.8 KiB
PHP
<?php
|
|
|
|
use MediaWiki\Extension\Notifications\Model\Event;
|
|
use MediaWiki\Extension\Notifications\Model\TargetPage;
|
|
|
|
/**
|
|
* @covers \MediaWiki\Extension\Notifications\Model\TargetPage
|
|
*/
|
|
class TargetPageTest extends MediaWikiUnitTestCase {
|
|
|
|
public function testCreate() {
|
|
$this->assertNull(
|
|
TargetPage::create(
|
|
$this->mockTitle( 0 ),
|
|
$this->mockEchoEvent()
|
|
)
|
|
);
|
|
|
|
$this->assertInstanceOf(
|
|
TargetPage::class,
|
|
TargetPage::create(
|
|
$this->mockTitle( 1 ),
|
|
$this->mockEchoEvent()
|
|
)
|
|
);
|
|
}
|
|
|
|
/**
|
|
* @return TargetPage
|
|
*/
|
|
public function testNewFromRow() {
|
|
$row = (object)[
|
|
'etp_page' => 2,
|
|
'etp_event' => 3
|
|
];
|
|
$obj = TargetPage::newFromRow( $row );
|
|
$this->assertInstanceOf( TargetPage::class, $obj );
|
|
|
|
return $obj;
|
|
}
|
|
|
|
public function testNewFromRowWithException() {
|
|
$row = (object)[
|
|
'etp_event' => 3
|
|
];
|
|
$this->expectException( MWException::class );
|
|
TargetPage::newFromRow( $row );
|
|
}
|
|
|
|
/**
|
|
* @depends testNewFromRow
|
|
*/
|
|
public function testToDbArray( TargetPage $obj ) {
|
|
$row = $obj->toDbArray();
|
|
$this->assertIsArray( $row );
|
|
|
|
// Not very common to assert that a field does _not_ exist
|
|
// but since we are explicitly removing it, it seems to make sense.
|
|
$this->assertArrayNotHasKey( 'etp_user', $row );
|
|
|
|
$this->assertArrayHasKey( 'etp_page', $row );
|
|
$this->assertArrayHasKey( 'etp_event', $row );
|
|
}
|
|
|
|
/**
|
|
* @param int $pageId
|
|
* @return Title
|
|
*/
|
|
protected function mockTitle( $pageId ) {
|
|
$event = $this->createMock( Title::class );
|
|
$event->method( 'getArticleID' )
|
|
->willReturn( $pageId );
|
|
|
|
return $event;
|
|
}
|
|
|
|
/**
|
|
* @param int $eventId
|
|
* @return Event
|
|
*/
|
|
protected function mockEchoEvent( $eventId = 1 ) {
|
|
$event = $this->createMock( Event::class );
|
|
$event->method( 'getId' )
|
|
->willReturn( $eventId );
|
|
|
|
return $event;
|
|
}
|
|
|
|
}
|