diff options
Diffstat (limited to 'tests/Test/Repair/Owncloud')
-rw-r--r-- | tests/Test/Repair/Owncloud/CleanPreviewsBackgroundJobTest.php | 228 | ||||
-rw-r--r-- | tests/Test/Repair/Owncloud/CleanPreviewsTest.php | 114 | ||||
-rw-r--r-- | tests/Test/Repair/Owncloud/UpdateLanguageCodesTest.php | 149 |
3 files changed, 0 insertions, 491 deletions
diff --git a/tests/Test/Repair/Owncloud/CleanPreviewsBackgroundJobTest.php b/tests/Test/Repair/Owncloud/CleanPreviewsBackgroundJobTest.php deleted file mode 100644 index 3d102c8f279..00000000000 --- a/tests/Test/Repair/Owncloud/CleanPreviewsBackgroundJobTest.php +++ /dev/null @@ -1,228 +0,0 @@ -<?php -/** - * SPDX-FileCopyrightText: 2016 Nextcloud GmbH and Nextcloud contributors - * SPDX-License-Identifier: AGPL-3.0-or-later - */ -namespace Test\Repair\Owncloud; - -use OC\Repair\Owncloud\CleanPreviewsBackgroundJob; -use OCP\AppFramework\Utility\ITimeFactory; -use OCP\BackgroundJob\IJobList; -use OCP\Files\Folder; -use OCP\Files\IRootFolder; -use OCP\Files\NotFoundException; -use OCP\Files\NotPermittedException; -use OCP\IUserManager; -use Psr\Log\LoggerInterface; -use Test\TestCase; - -class CleanPreviewsBackgroundJobTest extends TestCase { - /** @var IRootFolder|\PHPUnit_Framework_MockObject_MockObject */ - private $rootFolder; - - /** @var LoggerInterface|\PHPUnit_Framework_MockObject_MockObject */ - private $logger; - - /** @var IJobList|\PHPUnit_Framework_MockObject_MockObject */ - private $jobList; - - /** @var ITimeFactory|\PHPUnit_Framework_MockObject_MockObject */ - private $timeFactory; - - /** @var CleanPreviewsBackgroundJob */ - private $job; - - /** @var IUserManager|\PHPUnit_Framework_MockObject_MockObject */ - private $userManager; - - public function setUp(): void { - parent::setUp(); - - $this->rootFolder = $this->createMock(IRootFolder::class); - $this->logger = $this->createMock(LoggerInterface::class); - $this->jobList = $this->createMock(IJobList::class); - $this->timeFactory = $this->createMock(ITimeFactory::class); - $this->userManager = $this->createMock(IUserManager::class); - - $this->userManager->expects($this->any())->method('userExists')->willReturn(true); - - $this->job = new CleanPreviewsBackgroundJob( - $this->rootFolder, - $this->logger, - $this->jobList, - $this->timeFactory, - $this->userManager - ); - } - - public function testCleanupPreviewsUnfinished() { - $userFolder = $this->createMock(Folder::class); - $userRoot = $this->createMock(Folder::class); - $thumbnailFolder = $this->createMock(Folder::class); - - $this->rootFolder->method('getUserFolder') - ->with($this->equalTo('myuid')) - ->willReturn($userFolder); - - $userFolder->method('getParent')->willReturn($userRoot); - - $userRoot->method('get') - ->with($this->equalTo('thumbnails')) - ->willReturn($thumbnailFolder); - - $previewFolder1 = $this->createMock(Folder::class); - - $previewFolder1->expects($this->once()) - ->method('delete'); - - $thumbnailFolder->method('getDirectoryListing') - ->willReturn([$previewFolder1]); - $thumbnailFolder->expects($this->never()) - ->method('delete'); - - $this->timeFactory->method('getTime') - ->will($this->onConsecutiveCalls(100, 200)); - - $this->jobList->expects($this->once()) - ->method('add') - ->with( - $this->equalTo(CleanPreviewsBackgroundJob::class), - $this->equalTo(['uid' => 'myuid']) - ); - - $this->logger->expects($this->exactly(2)) - ->method('info') - ->withConsecutive( - [$this->equalTo('Started preview cleanup for myuid')], - [$this->equalTo('New preview cleanup scheduled for myuid')], - ); - - $this->job->run(['uid' => 'myuid']); - } - - public function testCleanupPreviewsFinished() { - $userFolder = $this->createMock(Folder::class); - $userRoot = $this->createMock(Folder::class); - $thumbnailFolder = $this->createMock(Folder::class); - - $this->rootFolder->method('getUserFolder') - ->with($this->equalTo('myuid')) - ->willReturn($userFolder); - - $userFolder->method('getParent')->willReturn($userRoot); - - $userRoot->method('get') - ->with($this->equalTo('thumbnails')) - ->willReturn($thumbnailFolder); - - $previewFolder1 = $this->createMock(Folder::class); - - $previewFolder1->expects($this->once()) - ->method('delete'); - - $thumbnailFolder->method('getDirectoryListing') - ->willReturn([$previewFolder1]); - - $this->timeFactory->method('getTime') - ->will($this->onConsecutiveCalls(100, 101)); - - $this->jobList->expects($this->never()) - ->method('add'); - - $this->logger->expects($this->exactly(2)) - ->method('info') - ->withConsecutive( - [$this->equalTo('Started preview cleanup for myuid')], - [$this->equalTo('Preview cleanup done for myuid')], - ); - - $thumbnailFolder->expects($this->once()) - ->method('delete'); - - $this->job->run(['uid' => 'myuid']); - } - - - public function testNoUserFolder() { - $this->rootFolder->method('getUserFolder') - ->with($this->equalTo('myuid')) - ->willThrowException(new NotFoundException()); - - $this->logger->expects($this->exactly(2)) - ->method('info') - ->withConsecutive( - [$this->equalTo('Started preview cleanup for myuid')], - [$this->equalTo('Preview cleanup done for myuid')], - ); - - $this->job->run(['uid' => 'myuid']); - } - - public function testNoThumbnailFolder() { - $userFolder = $this->createMock(Folder::class); - $userRoot = $this->createMock(Folder::class); - - $this->rootFolder->method('getUserFolder') - ->with($this->equalTo('myuid')) - ->willReturn($userFolder); - - $userFolder->method('getParent')->willReturn($userRoot); - - $userRoot->method('get') - ->with($this->equalTo('thumbnails')) - ->willThrowException(new NotFoundException()); - - $this->logger->expects($this->exactly(2)) - ->method('info') - ->withConsecutive( - [$this->equalTo('Started preview cleanup for myuid')], - [$this->equalTo('Preview cleanup done for myuid')], - ); - - $this->job->run(['uid' => 'myuid']); - } - - public function testNotPermittedToDelete() { - $userFolder = $this->createMock(Folder::class); - $userRoot = $this->createMock(Folder::class); - $thumbnailFolder = $this->createMock(Folder::class); - - $this->rootFolder->method('getUserFolder') - ->with($this->equalTo('myuid')) - ->willReturn($userFolder); - - $userFolder->method('getParent')->willReturn($userRoot); - - $userRoot->method('get') - ->with($this->equalTo('thumbnails')) - ->willReturn($thumbnailFolder); - - $previewFolder1 = $this->createMock(Folder::class); - - $previewFolder1->expects($this->once()) - ->method('delete') - ->willThrowException(new NotPermittedException()); - - $thumbnailFolder->method('getDirectoryListing') - ->willReturn([$previewFolder1]); - - $this->timeFactory->method('getTime') - ->will($this->onConsecutiveCalls(100, 101)); - - $this->jobList->expects($this->never()) - ->method('add'); - - $this->logger->expects($this->exactly(2)) - ->method('info') - ->withConsecutive( - [$this->equalTo('Started preview cleanup for myuid')], - [$this->equalTo('Preview cleanup done for myuid')], - ); - - $thumbnailFolder->expects($this->once()) - ->method('delete') - ->willThrowException(new NotPermittedException()); - - $this->job->run(['uid' => 'myuid']); - } -} diff --git a/tests/Test/Repair/Owncloud/CleanPreviewsTest.php b/tests/Test/Repair/Owncloud/CleanPreviewsTest.php deleted file mode 100644 index 10d2e5d216c..00000000000 --- a/tests/Test/Repair/Owncloud/CleanPreviewsTest.php +++ /dev/null @@ -1,114 +0,0 @@ -<?php -/** - * SPDX-FileCopyrightText: 2016 Nextcloud GmbH and Nextcloud contributors - * SPDX-License-Identifier: AGPL-3.0-or-later - */ -namespace Test\Repair\Owncloud; - -use OC\Repair\Owncloud\CleanPreviews; -use OC\Repair\Owncloud\CleanPreviewsBackgroundJob; -use OCP\BackgroundJob\IJobList; -use OCP\IConfig; -use OCP\IUser; -use OCP\IUserManager; -use OCP\Migration\IOutput; -use Test\TestCase; - -class CleanPreviewsTest extends TestCase { - /** @var IJobList|\PHPUnit_Framework_MockObject_MockObject */ - private $jobList; - - /** @var IUserManager|\PHPUnit_Framework_MockObject_MockObject */ - private $userManager; - - /** @var IConfig|\PHPUnit_Framework_MockObject_MockObject */ - private $config; - - /** @var CleanPreviews */ - private $repair; - - public function setUp(): void { - parent::setUp(); - - $this->jobList = $this->createMock(IJobList::class); - $this->userManager = $this->createMock(IUserManager::class); - $this->config = $this->createMock(IConfig::class); - - $this->repair = new CleanPreviews( - $this->jobList, - $this->userManager, - $this->config - ); - } - - public function testGetName() { - $this->assertSame('Add preview cleanup background jobs', $this->repair->getName()); - } - - public function testRun() { - $user1 = $this->createMock(IUser::class); - $user1->method('getUID') - ->willReturn('user1'); - $user2 = $this->createMock(IUser::class); - $user2->method('getUID') - ->willReturn('user2'); - - $this->userManager->expects($this->once()) - ->method('callForSeenUsers') - ->will($this->returnCallback(function (\Closure $function) use ($user1, $user2) { - $function($user1); - $function($user2); - })); - - $this->jobList->expects($this->exactly(2)) - ->method('add') - ->withConsecutive( - [ - $this->equalTo(CleanPreviewsBackgroundJob::class), - $this->equalTo(['uid' => 'user1']) - ], - [ - $this->equalTo(CleanPreviewsBackgroundJob::class), - $this->equalTo(['uid' => 'user2']) - ], - ); - - $this->config->expects($this->once()) - ->method('getAppValue') - ->with( - $this->equalTo('core'), - $this->equalTo('previewsCleanedUp'), - $this->equalTo(false) - )->willReturn(false); - $this->config->expects($this->once()) - ->method('setAppValue') - ->with( - $this->equalTo('core'), - $this->equalTo('previewsCleanedUp'), - $this->equalTo(1) - ); - - $this->repair->run($this->createMock(IOutput::class)); - } - - - public function testRunAlreadyDoone() { - $this->userManager->expects($this->never()) - ->method($this->anything()); - - $this->jobList->expects($this->never()) - ->method($this->anything()); - - $this->config->expects($this->once()) - ->method('getAppValue') - ->with( - $this->equalTo('core'), - $this->equalTo('previewsCleanedUp'), - $this->equalTo(false) - )->willReturn('1'); - $this->config->expects($this->never()) - ->method('setAppValue'); - - $this->repair->run($this->createMock(IOutput::class)); - } -} diff --git a/tests/Test/Repair/Owncloud/UpdateLanguageCodesTest.php b/tests/Test/Repair/Owncloud/UpdateLanguageCodesTest.php deleted file mode 100644 index 856adde5c95..00000000000 --- a/tests/Test/Repair/Owncloud/UpdateLanguageCodesTest.php +++ /dev/null @@ -1,149 +0,0 @@ -<?php -/** - * SPDX-FileCopyrightText: 2016 Nextcloud GmbH and Nextcloud contributors - * SPDX-License-Identifier: AGPL-3.0-or-later - */ - -namespace Test\Repair\Owncloud; - -use OC\Repair\Owncloud\UpdateLanguageCodes; -use OCP\DB\QueryBuilder\IQueryBuilder; -use OCP\IConfig; -use OCP\Migration\IOutput; -use Test\TestCase; - -/** - * Class UpdateLanguageCodesTest - * - * @group DB - * - * @package Test\Repair - */ -class UpdateLanguageCodesTest extends TestCase { - /** @var \OCP\IDBConnection */ - protected $connection; - - /** @var IConfig | \PHPUnit_Framework_MockObject_MockObject */ - private $config; - - protected function setUp(): void { - parent::setUp(); - - $this->connection = \OC::$server->getDatabaseConnection(); - $this->config = $this->createMock(IConfig::class); - } - - public function testRun() { - $users = [ - ['userid' => 'user1', 'configvalue' => 'fi_FI'], - ['userid' => 'user2', 'configvalue' => 'de'], - ['userid' => 'user3', 'configvalue' => 'fi'], - ['userid' => 'user4', 'configvalue' => 'ja'], - ['userid' => 'user5', 'configvalue' => 'bg_BG'], - ['userid' => 'user6', 'configvalue' => 'ja'], - ['userid' => 'user7', 'configvalue' => 'th_TH'], - ['userid' => 'user8', 'configvalue' => 'th_TH'], - ]; - - // insert test data - $qb = $this->connection->getQueryBuilder(); - $qb->insert('preferences') - ->values([ - 'userid' => $qb->createParameter('userid'), - 'appid' => $qb->createParameter('appid'), - 'configkey' => $qb->createParameter('configkey'), - 'configvalue' => $qb->createParameter('configvalue'), - ]); - foreach ($users as $user) { - $qb->setParameters([ - 'userid' => $user['userid'], - 'appid' => 'core', - 'configkey' => 'lang', - 'configvalue' => $user['configvalue'], - ])->execute(); - } - - // check if test data is written to DB - $qb = $this->connection->getQueryBuilder(); - $result = $qb->select(['userid', 'configvalue']) - ->from('preferences') - ->where($qb->expr()->eq('appid', $qb->createNamedParameter('core'))) - ->andWhere($qb->expr()->eq('configkey', $qb->createNamedParameter('lang'))) - ->orderBy('userid') - ->execute(); - - $rows = $result->fetchAll(); - $result->closeCursor(); - - $this->assertSame($users, $rows, 'Asserts that the entries are the ones from the test data set'); - - /** @var IOutput|\PHPUnit_Framework_MockObject_MockObject $outputMock */ - $outputMock = $this->createMock(IOutput::class); - $outputMock->expects($this->exactly(7)) - ->method('info') - ->withConsecutive( - ['Changed 1 setting(s) from "bg_BG" to "bg" in preferences table.'], - ['Changed 0 setting(s) from "cs_CZ" to "cs" in preferences table.'], - ['Changed 1 setting(s) from "fi_FI" to "fi" in preferences table.'], - ['Changed 0 setting(s) from "hu_HU" to "hu" in preferences table.'], - ['Changed 0 setting(s) from "nb_NO" to "nb" in preferences table.'], - ['Changed 0 setting(s) from "sk_SK" to "sk" in preferences table.'], - ['Changed 2 setting(s) from "th_TH" to "th" in preferences table.'], - ); - - $this->config->expects($this->once()) - ->method('getSystemValueString') - ->with('version', '0.0.0') - ->willReturn('12.0.0.13'); - - // run repair step - $repair = new UpdateLanguageCodes($this->connection, $this->config); - $repair->run($outputMock); - - // check if test data is correctly modified in DB - $qb = $this->connection->getQueryBuilder(); - $result = $qb->select(['userid', 'configvalue']) - ->from('preferences') - ->where($qb->expr()->eq('appid', $qb->createNamedParameter('core'))) - ->andWhere($qb->expr()->eq('configkey', $qb->createNamedParameter('lang'))) - ->orderBy('userid') - ->execute(); - - $rows = $result->fetchAll(); - $result->closeCursor(); - - // value has changed for one user - $users[0]['configvalue'] = 'fi'; - $users[4]['configvalue'] = 'bg'; - $users[6]['configvalue'] = 'th'; - $users[7]['configvalue'] = 'th'; - $this->assertSame($users, $rows, 'Asserts that the entries are updated correctly.'); - - // remove test data - foreach ($users as $user) { - $qb = $this->connection->getQueryBuilder(); - $qb->delete('preferences') - ->where($qb->expr()->eq('userid', $qb->createNamedParameter($user['userid']))) - ->andWhere($qb->expr()->eq('appid', $qb->createNamedParameter('core'))) - ->andWhere($qb->expr()->eq('configkey', $qb->createNamedParameter('lang'))) - ->andWhere($qb->expr()->eq('configvalue', $qb->createNamedParameter($user['configvalue']), IQueryBuilder::PARAM_STR)) - ->execute(); - } - } - - public function testSecondRun() { - /** @var IOutput|\PHPUnit_Framework_MockObject_MockObject $outputMock */ - $outputMock = $this->createMock(IOutput::class); - $outputMock->expects($this->never()) - ->method('info'); - - $this->config->expects($this->once()) - ->method('getSystemValueString') - ->with('version', '0.0.0') - ->willReturn('12.0.0.14'); - - // run repair step - $repair = new UpdateLanguageCodes($this->connection, $this->config); - $repair->run($outputMock); - } -} |