123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346 |
- <?php
- declare(strict_types=1);
- /**
- * SPDX-FileCopyrightText: 2020 Nextcloud GmbH and Nextcloud contributors
- * SPDX-License-Identifier: AGPL-3.0-or-later
- */
- namespace OCA\UserStatus\Tests\Db;
- use OCA\UserStatus\Db\UserStatus;
- use OCA\UserStatus\Db\UserStatusMapper;
- use OCP\AppFramework\Db\DoesNotExistException;
- use OCP\DB\Exception;
- use Test\TestCase;
- class UserStatusMapperTest extends TestCase {
- /** @var UserStatusMapper */
- private $mapper;
- protected function setUp(): void {
- parent::setUp();
- // make sure that DB is empty
- $qb = self::$realDatabase->getQueryBuilder();
- $qb->delete('user_status')->execute();
- $this->mapper = new UserStatusMapper(self::$realDatabase);
- }
- public function testGetTableName(): void {
- $this->assertEquals('user_status', $this->mapper->getTableName());
- }
- public function testGetFindAll(): void {
- $this->insertSampleStatuses();
- $allResults = $this->mapper->findAll();
- $this->assertCount(3, $allResults);
- $limitedResults = $this->mapper->findAll(2);
- $this->assertCount(2, $limitedResults);
- $this->assertEquals('admin', $limitedResults[0]->getUserId());
- $this->assertEquals('user1', $limitedResults[1]->getUserId());
- $offsetResults = $this->mapper->findAll(null, 2);
- $this->assertCount(1, $offsetResults);
- $this->assertEquals('user2', $offsetResults[0]->getUserId());
- }
- public function testFindAllRecent(): void {
- $this->insertSampleStatuses();
- $allResults = $this->mapper->findAllRecent(2, 0);
- $this->assertCount(2, $allResults);
- $this->assertEquals('user2', $allResults[0]->getUserId());
- $this->assertEquals('user1', $allResults[1]->getUserId());
- }
- public function testGetFind(): void {
- $this->insertSampleStatuses();
- $adminStatus = $this->mapper->findByUserId('admin');
- $this->assertEquals('admin', $adminStatus->getUserId());
- $this->assertEquals('offline', $adminStatus->getStatus());
- $this->assertEquals(0, $adminStatus->getStatusTimestamp());
- $this->assertEquals(false, $adminStatus->getIsUserDefined());
- $this->assertEquals(null, $adminStatus->getCustomIcon());
- $this->assertEquals(null, $adminStatus->getCustomMessage());
- $this->assertEquals(null, $adminStatus->getClearAt());
- $user1Status = $this->mapper->findByUserId('user1');
- $this->assertEquals('user1', $user1Status->getUserId());
- $this->assertEquals('dnd', $user1Status->getStatus());
- $this->assertEquals(5000, $user1Status->getStatusTimestamp());
- $this->assertEquals(true, $user1Status->getIsUserDefined());
- $this->assertEquals('💩', $user1Status->getCustomIcon());
- $this->assertEquals('Do not disturb', $user1Status->getCustomMessage());
- $this->assertEquals(50000, $user1Status->getClearAt());
- $user2Status = $this->mapper->findByUserId('user2');
- $this->assertEquals('user2', $user2Status->getUserId());
- $this->assertEquals('away', $user2Status->getStatus());
- $this->assertEquals(6000, $user2Status->getStatusTimestamp());
- $this->assertEquals(false, $user2Status->getIsUserDefined());
- $this->assertEquals('🏝', $user2Status->getCustomIcon());
- $this->assertEquals('On vacation', $user2Status->getCustomMessage());
- $this->assertEquals(60000, $user2Status->getClearAt());
- }
- public function testFindByUserIds(): void {
- $this->insertSampleStatuses();
- $statuses = $this->mapper->findByUserIds(['admin', 'user2']);
- $this->assertCount(2, $statuses);
- $adminStatus = $statuses[0];
- $this->assertEquals('admin', $adminStatus->getUserId());
- $this->assertEquals('offline', $adminStatus->getStatus());
- $this->assertEquals(0, $adminStatus->getStatusTimestamp());
- $this->assertEquals(false, $adminStatus->getIsUserDefined());
- $this->assertEquals(null, $adminStatus->getCustomIcon());
- $this->assertEquals(null, $adminStatus->getCustomMessage());
- $this->assertEquals(null, $adminStatus->getClearAt());
- $user2Status = $statuses[1];
- $this->assertEquals('user2', $user2Status->getUserId());
- $this->assertEquals('away', $user2Status->getStatus());
- $this->assertEquals(6000, $user2Status->getStatusTimestamp());
- $this->assertEquals(false, $user2Status->getIsUserDefined());
- $this->assertEquals('🏝', $user2Status->getCustomIcon());
- $this->assertEquals('On vacation', $user2Status->getCustomMessage());
- $this->assertEquals(60000, $user2Status->getClearAt());
- }
- public function testUserIdUnique(): void {
- // Test that inserting a second status for a user is throwing an exception
- $userStatus1 = new UserStatus();
- $userStatus1->setUserId('admin');
- $userStatus1->setStatus('dnd');
- $userStatus1->setStatusTimestamp(5000);
- $userStatus1->setIsUserDefined(true);
- $this->mapper->insert($userStatus1);
- $userStatus2 = new UserStatus();
- $userStatus2->setUserId('admin');
- $userStatus2->setStatus('away');
- $userStatus2->setStatusTimestamp(6000);
- $userStatus2->setIsUserDefined(false);
- $this->expectException(Exception::class);
- $this->mapper->insert($userStatus2);
- }
- /**
- * @param string $status
- * @param bool $isUserDefined
- * @param int $timestamp
- * @param bool $expectsClean
- *
- * @dataProvider clearStatusesOlderThanDataProvider
- */
- public function testClearStatusesOlderThan(string $status, bool $isUserDefined, int $timestamp, bool $expectsClean): void {
- $oldStatus = UserStatus::fromParams([
- 'userId' => 'john.doe',
- 'status' => $status,
- 'isUserDefined' => $isUserDefined,
- 'statusTimestamp' => $timestamp,
- ]);
- $this->mapper->insert($oldStatus);
- $this->mapper->clearStatusesOlderThan(5000, 8000);
- $updatedStatus = $this->mapper->findAll()[0];
- if ($expectsClean) {
- $this->assertEquals('offline', $updatedStatus->getStatus());
- $this->assertFalse($updatedStatus->getIsUserDefined());
- $this->assertEquals(8000, $updatedStatus->getStatusTimestamp());
- } else {
- $this->assertEquals($status, $updatedStatus->getStatus());
- $this->assertEquals($isUserDefined, $updatedStatus->getIsUserDefined());
- $this->assertEquals($timestamp, $updatedStatus->getStatusTimestamp());
- }
- }
- public function clearStatusesOlderThanDataProvider(): array {
- return [
- ['offline', false, 6000, false],
- ['online', true, 6000, false],
- ['online', true, 4000, true],
- ['online', false, 6000, false],
- ['online', false, 4000, true],
- ['away', true, 6000, false],
- ['away', true, 4000, false],
- ['away', false, 6000, false],
- ['away', false, 4000, true],
- ['dnd', true, 6000, false],
- ['dnd', true, 4000, false],
- ['invisible', true, 6000, false],
- ['invisible', true, 4000, false],
- ];
- }
- public function testClearOlderThanClearAt(): void {
- $this->insertSampleStatuses();
- $this->mapper->clearOlderThanClearAt(55000);
- $allStatuses = $this->mapper->findAll();
- $this->assertCount(2, $allStatuses);
- $this->expectException(DoesNotExistException::class);
- $this->mapper->findByUserId('user1');
- }
- private function insertSampleStatuses(): void {
- $userStatus1 = new UserStatus();
- $userStatus1->setUserId('admin');
- $userStatus1->setStatus('offline');
- $userStatus1->setStatusTimestamp(0);
- $userStatus1->setIsUserDefined(false);
- $userStatus2 = new UserStatus();
- $userStatus2->setUserId('user1');
- $userStatus2->setStatus('dnd');
- $userStatus2->setStatusTimestamp(5000);
- $userStatus2->setStatusMessageTimestamp(5000);
- $userStatus2->setIsUserDefined(true);
- $userStatus2->setCustomIcon('💩');
- $userStatus2->setCustomMessage('Do not disturb');
- $userStatus2->setClearAt(50000);
- $userStatus3 = new UserStatus();
- $userStatus3->setUserId('user2');
- $userStatus3->setStatus('away');
- $userStatus3->setStatusTimestamp(6000);
- $userStatus3->setStatusMessageTimestamp(6000);
- $userStatus3->setIsUserDefined(false);
- $userStatus3->setCustomIcon('🏝');
- $userStatus3->setCustomMessage('On vacation');
- $userStatus3->setClearAt(60000);
- $this->mapper->insert($userStatus1);
- $this->mapper->insert($userStatus2);
- $this->mapper->insert($userStatus3);
- }
- public function dataCreateBackupStatus(): array {
- return [
- [false, false, false],
- [true, false, true],
- [false, true, false],
- [true, true, false],
- ];
- }
- /**
- * @dataProvider dataCreateBackupStatus
- * @param bool $hasStatus
- * @param bool $hasBackup
- * @param bool $backupCreated
- */
- public function testCreateBackupStatus(bool $hasStatus, bool $hasBackup, bool $backupCreated): void {
- if ($hasStatus) {
- $userStatus1 = new UserStatus();
- $userStatus1->setUserId('user1');
- $userStatus1->setStatus('online');
- $userStatus1->setStatusTimestamp(5000);
- $userStatus1->setIsUserDefined(true);
- $userStatus1->setIsBackup(false);
- $userStatus1->setCustomIcon('🚀');
- $userStatus1->setCustomMessage('Current');
- $userStatus1->setClearAt(50000);
- $this->mapper->insert($userStatus1);
- }
- if ($hasBackup) {
- $userStatus1 = new UserStatus();
- $userStatus1->setUserId('_user1');
- $userStatus1->setStatus('online');
- $userStatus1->setStatusTimestamp(5000);
- $userStatus1->setIsUserDefined(true);
- $userStatus1->setIsBackup(true);
- $userStatus1->setCustomIcon('🚀');
- $userStatus1->setCustomMessage('Backup');
- $userStatus1->setClearAt(50000);
- $this->mapper->insert($userStatus1);
- }
- if ($hasStatus && $hasBackup) {
- $this->expectException(Exception::class);
- }
- self::assertSame($backupCreated, $this->mapper->createBackupStatus('user1'));
- if ($backupCreated) {
- $user1Status = $this->mapper->findByUserId('user1', true);
- $this->assertEquals('_user1', $user1Status->getUserId());
- $this->assertEquals(true, $user1Status->getIsBackup());
- $this->assertEquals('Current', $user1Status->getCustomMessage());
- } elseif ($hasBackup) {
- $user1Status = $this->mapper->findByUserId('user1', true);
- $this->assertEquals('_user1', $user1Status->getUserId());
- $this->assertEquals(true, $user1Status->getIsBackup());
- $this->assertEquals('Backup', $user1Status->getCustomMessage());
- }
- }
- public function testRestoreBackupStatuses(): void {
- $userStatus1 = new UserStatus();
- $userStatus1->setUserId('_user1');
- $userStatus1->setStatus('online');
- $userStatus1->setStatusTimestamp(5000);
- $userStatus1->setIsUserDefined(true);
- $userStatus1->setIsBackup(true);
- $userStatus1->setCustomIcon('🚀');
- $userStatus1->setCustomMessage('Releasing');
- $userStatus1->setClearAt(50000);
- $userStatus1 = $this->mapper->insert($userStatus1);
- $userStatus2 = new UserStatus();
- $userStatus2->setUserId('_user2');
- $userStatus2->setStatus('away');
- $userStatus2->setStatusTimestamp(5000);
- $userStatus2->setIsUserDefined(true);
- $userStatus2->setIsBackup(true);
- $userStatus2->setCustomIcon('💩');
- $userStatus2->setCustomMessage('Do not disturb');
- $userStatus2->setClearAt(50000);
- $userStatus2 = $this->mapper->insert($userStatus2);
- $userStatus3 = new UserStatus();
- $userStatus3->setUserId('_user3');
- $userStatus3->setStatus('away');
- $userStatus3->setStatusTimestamp(5000);
- $userStatus3->setIsUserDefined(true);
- $userStatus3->setIsBackup(true);
- $userStatus3->setCustomIcon('🏝️');
- $userStatus3->setCustomMessage('Vacationing');
- $userStatus3->setClearAt(50000);
- $this->mapper->insert($userStatus3);
- $this->mapper->restoreBackupStatuses([$userStatus1->getId(), $userStatus2->getId()]);
- $user1Status = $this->mapper->findByUserId('user1', false);
- $this->assertEquals('user1', $user1Status->getUserId());
- $this->assertEquals(false, $user1Status->getIsBackup());
- $this->assertEquals('Releasing', $user1Status->getCustomMessage());
- $user2Status = $this->mapper->findByUserId('user2', false);
- $this->assertEquals('user2', $user2Status->getUserId());
- $this->assertEquals(false, $user2Status->getIsBackup());
- $this->assertEquals('Do not disturb', $user2Status->getCustomMessage());
- $user3Status = $this->mapper->findByUserId('user3', true);
- $this->assertEquals('_user3', $user3Status->getUserId());
- $this->assertEquals(true, $user3Status->getIsBackup());
- $this->assertEquals('Vacationing', $user3Status->getCustomMessage());
- }
- }
|