123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287 |
- <?php
- namespace Test\Activity;
- use OCP\Activity\Exceptions\IncompleteActivityException;
- use OCP\IConfig;
- use OCP\IL10N;
- use OCP\IRequest;
- use OCP\IUser;
- use OCP\IUserSession;
- use OCP\RichObjectStrings\IRichTextFormatter;
- use OCP\RichObjectStrings\IValidator;
- use PHPUnit\Framework\MockObject\MockObject;
- use Test\TestCase;
- class ManagerTest extends TestCase {
-
- private $activityManager;
- protected IRequest&MockObject $request;
- protected IUserSession&MockObject $session;
- protected IConfig&MockObject $config;
- protected IValidator&MockObject $validator;
- protected IRichTextFormatter&MockObject $richTextFormatter;
- protected function setUp(): void {
- parent::setUp();
- $this->request = $this->createMock(IRequest::class);
- $this->session = $this->createMock(IUserSession::class);
- $this->config = $this->createMock(IConfig::class);
- $this->validator = $this->createMock(IValidator::class);
- $this->richTextFormatter = $this->createMock(IRichTextFormatter::class);
- $this->activityManager = new \OC\Activity\Manager(
- $this->request,
- $this->session,
- $this->config,
- $this->validator,
- $this->richTextFormatter,
- $this->createMock(IL10N::class)
- );
- $this->assertSame([], self::invokePrivate($this->activityManager, 'getConsumers'));
- $this->activityManager->registerConsumer(function () {
- return new NoOpConsumer();
- });
- $this->assertNotEmpty(self::invokePrivate($this->activityManager, 'getConsumers'));
- $this->assertNotEmpty(self::invokePrivate($this->activityManager, 'getConsumers'));
- }
- public function testGetConsumers(): void {
- $consumers = self::invokePrivate($this->activityManager, 'getConsumers');
- $this->assertNotEmpty($consumers);
- }
- public function testGetConsumersInvalidConsumer(): void {
- $this->expectException(\InvalidArgumentException::class);
- $this->activityManager->registerConsumer(function () {
- return new \stdClass();
- });
- self::invokePrivate($this->activityManager, 'getConsumers');
- }
- public function getUserFromTokenThrowInvalidTokenData() {
- return [
- [null, []],
- ['', []],
- ['12345678901234567890123456789', []],
- ['1234567890123456789012345678901', []],
- ['123456789012345678901234567890', []],
- ['123456789012345678901234567890', ['user1', 'user2']],
- ];
- }
-
- public function testGetUserFromTokenThrowInvalidToken($token, $users): void {
- $this->expectException(\UnexpectedValueException::class);
- $this->mockRSSToken($token, $token, $users);
- self::invokePrivate($this->activityManager, 'getUserFromToken');
- }
- public function getUserFromTokenData() {
- return [
- [null, '123456789012345678901234567890', 'user1'],
- ['user2', null, 'user2'],
- ['user2', '123456789012345678901234567890', 'user2'],
- ];
- }
-
- public function testGetUserFromToken($userLoggedIn, $token, $expected): void {
- if ($userLoggedIn !== null) {
- $this->mockUserSession($userLoggedIn);
- }
- $this->mockRSSToken($token, '123456789012345678901234567890', ['user1']);
- $this->assertEquals($expected, $this->activityManager->getCurrentUserId());
- }
- protected function mockRSSToken($requestToken, $userToken, $users) {
- if ($requestToken !== null) {
- $this->request->expects($this->any())
- ->method('getParam')
- ->with('token', '')
- ->willReturn($requestToken);
- }
- $this->config->expects($this->any())
- ->method('getUsersForUserValue')
- ->with('activity', 'rsstoken', $userToken)
- ->willReturn($users);
- }
- protected function mockUserSession($user) {
- $mockUser = $this->getMockBuilder(IUser::class)
- ->disableOriginalConstructor()
- ->getMock();
- $mockUser->expects($this->any())
- ->method('getUID')
- ->willReturn($user);
- $this->session->expects($this->any())
- ->method('isLoggedIn')
- ->willReturn(true);
- $this->session->expects($this->any())
- ->method('getUser')
- ->willReturn($mockUser);
- }
- public function testPublishExceptionNoApp(): void {
- $this->expectException(IncompleteActivityException::class);
- $event = $this->activityManager->generateEvent();
- $this->activityManager->publish($event);
- }
- public function testPublishExceptionNoType(): void {
- $this->expectException(IncompleteActivityException::class);
- $event = $this->activityManager->generateEvent();
- $event->setApp('test');
- $this->activityManager->publish($event);
- }
- public function testPublishExceptionNoAffectedUser(): void {
- $this->expectException(IncompleteActivityException::class);
- $event = $this->activityManager->generateEvent();
- $event->setApp('test')
- ->setType('test_type');
- $this->activityManager->publish($event);
- }
- public function testPublishExceptionNoSubject(): void {
- $this->expectException(IncompleteActivityException::class);
- $event = $this->activityManager->generateEvent();
- $event->setApp('test')
- ->setType('test_type')
- ->setAffectedUser('test_affected');
- $this->activityManager->publish($event);
- }
- public function dataPublish() {
- return [
- [null, ''],
- ['test_author', 'test_author'],
- ];
- }
-
- public function testPublish($author, $expected): void {
- if ($author !== null) {
- $authorObject = $this->getMockBuilder(IUser::class)
- ->disableOriginalConstructor()
- ->getMock();
- $authorObject->expects($this->once())
- ->method('getUID')
- ->willReturn($author);
- $this->session->expects($this->atLeastOnce())
- ->method('getUser')
- ->willReturn($authorObject);
- }
- $event = $this->activityManager->generateEvent();
- $event->setApp('test')
- ->setType('test_type')
- ->setSubject('test_subject', [])
- ->setAffectedUser('test_affected')
- ->setObject('file', 123);
- $consumer = $this->getMockBuilder('OCP\Activity\IConsumer')
- ->disableOriginalConstructor()
- ->getMock();
- $consumer->expects($this->once())
- ->method('receive')
- ->with($event)
- ->willReturnCallback(function (\OCP\Activity\IEvent $event) use ($expected) {
- $this->assertLessThanOrEqual(time() + 2, $event->getTimestamp(), 'Timestamp not set correctly');
- $this->assertGreaterThanOrEqual(time() - 2, $event->getTimestamp(), 'Timestamp not set correctly');
- $this->assertSame($expected, $event->getAuthor(), 'Author name not set correctly');
- });
- $this->activityManager->registerConsumer(function () use ($consumer) {
- return $consumer;
- });
- $this->activityManager->publish($event);
- }
- public function testPublishAllManually(): void {
- $event = $this->activityManager->generateEvent();
- $event->setApp('test_app')
- ->setType('test_type')
- ->setAffectedUser('test_affected')
- ->setAuthor('test_author')
- ->setTimestamp(1337)
- ->setSubject('test_subject', ['test_subject_param'])
- ->setMessage('test_message', ['test_message_param'])
- ->setObject('test_object_type', 42, 'test_object_name')
- ->setLink('test_link')
- ;
- $consumer = $this->getMockBuilder('OCP\Activity\IConsumer')
- ->disableOriginalConstructor()
- ->getMock();
- $consumer->expects($this->once())
- ->method('receive')
- ->willReturnCallback(function (\OCP\Activity\IEvent $event) {
- $this->assertSame('test_app', $event->getApp(), 'App not set correctly');
- $this->assertSame('test_type', $event->getType(), 'Type not set correctly');
- $this->assertSame('test_affected', $event->getAffectedUser(), 'Affected user not set correctly');
- $this->assertSame('test_author', $event->getAuthor(), 'Author not set correctly');
- $this->assertSame(1337, $event->getTimestamp(), 'Timestamp not set correctly');
- $this->assertSame('test_subject', $event->getSubject(), 'Subject not set correctly');
- $this->assertSame(['test_subject_param'], $event->getSubjectParameters(), 'Subject parameter not set correctly');
- $this->assertSame('test_message', $event->getMessage(), 'Message not set correctly');
- $this->assertSame(['test_message_param'], $event->getMessageParameters(), 'Message parameter not set correctly');
- $this->assertSame('test_object_type', $event->getObjectType(), 'Object type not set correctly');
- $this->assertSame(42, $event->getObjectId(), 'Object ID not set correctly');
- $this->assertSame('test_object_name', $event->getObjectName(), 'Object name not set correctly');
- $this->assertSame('test_link', $event->getLink(), 'Link not set correctly');
- });
- $this->activityManager->registerConsumer(function () use ($consumer) {
- return $consumer;
- });
- $this->activityManager->publish($event);
- }
- }
- class NoOpConsumer implements \OCP\Activity\IConsumer {
- public function receive(\OCP\Activity\IEvent $event) {
- }
- }
|