mediawiki-extensions-Echo/tests/phpunit/BundlerTest.php
James D. Forrester 8c810dff48 build: Update mediawiki/mediawiki-codesniffer to 0.7.1
Also added "composer fix" command.

Change-Id: I25cb61b3b92798f1259d1575a336e2b056d5764f
2016-12-05 15:54:30 -08:00

46 lines
1.6 KiB
PHP

<?php
class BundlerTest extends MediaWikiTestCase {
public function testBundle() {
$read = true;
$unread = false;
$n1 = $this->createNotificationForBundling( 'bundle_hash_1', 'timestamp_4', $read );
$n2 = $this->createNotificationForBundling( 'bundle_hash_1', 'timestamp_1', $read );
$n3 = $this->createNotificationForBundling( 'bundle_hash_2', 'timestamp_3', $unread );
$n4 = $this->createNotificationForBundling( 'bundle_hash_2', 'timestamp_2', $unread );
$n5 = $this->createNotificationForBundling( 'bundle_hash_2', 'timestamp_5', $read );
$notifications = [ $n1, $n2, $n3, $n4, $n5 ];
$bundler = new Bundler();
$bundledNotifications = $bundler->bundle( $notifications );
$this->assertCount( 4, $bundledNotifications );
$this->assertSame( $n5, $bundledNotifications[0] );
$this->assertSame( $n1, $bundledNotifications[1] );
$this->assertSame( $n3, $bundledNotifications[2] );
$this->assertCount( 1, $bundledNotifications[2]->getBundledNotifications() );
$this->assertSame( $n4, $bundledNotifications[2]->getBundledNotifications()[0] );
$this->assertSame( $n2, $bundledNotifications[3] );
}
private function createNotificationForBundling( $bundleHash, $timestamp, $readStatus ) {
$mock = $this->getMockBuilder( 'EchoNotification' )
->disableOriginalConstructor()
->setMethods( [
'getBundlingKey',
'getSortingKey',
'canBeBundled',
] )
->getMock();
$mock->method( 'getBundlingKey' )->willReturn( $bundleHash );
$mock->method( 'getSortingKey' )->willReturn( $timestamp );
$mock->method( 'canBeBundled' )->willReturn( !$readStatus );
return $mock;
}
}