123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144 |
- <?php
- /**
- * SPDX-FileCopyrightText: 2017-2024 Nextcloud GmbH and Nextcloud contributors
- * SPDX-FileCopyrightText: 2016 ownCloud, Inc.
- * SPDX-License-Identifier: AGPL-3.0-only
- */
- namespace OCA\Files_Sharing\Tests;
- use OC\Files\Filesystem;
- use OCA\Files_Sharing\DeleteOrphanedSharesJob;
- use OCP\Constants;
- use OCP\IDBConnection;
- use OCP\Server;
- use OCP\Share\IShare;
- /**
- * Class DeleteOrphanedSharesJobTest
- *
- * @group DB
- *
- * @package OCA\Files_Sharing\Tests
- */
- class DeleteOrphanedSharesJobTest extends \Test\TestCase {
- /**
- * @var bool
- */
- private static $trashBinStatus;
- /**
- * @var DeleteOrphanedSharesJob
- */
- private $job;
- /**
- * @var IDBConnection
- */
- private $connection;
- /**
- * @var string
- */
- private $user1;
- /**
- * @var string
- */
- private $user2;
- public static function setUpBeforeClass(): void {
- $appManager = \OC::$server->getAppManager();
- self::$trashBinStatus = $appManager->isEnabledForUser('files_trashbin');
- $appManager->disableApp('files_trashbin');
- // just in case...
- Filesystem::getLoader()->removeStorageWrapper('oc_trashbin');
- }
- public static function tearDownAfterClass(): void {
- if (self::$trashBinStatus) {
- \OC::$server->getAppManager()->enableApp('files_trashbin');
- }
- }
- protected function setUp(): void {
- parent::setUp();
- $this->connection = \OC::$server->getDatabaseConnection();
- // clear occasional leftover shares from other tests
- $this->connection->executeUpdate('DELETE FROM `*PREFIX*share`');
- $this->user1 = $this->getUniqueID('user1_');
- $this->user2 = $this->getUniqueID('user2_');
- $userManager = \OC::$server->getUserManager();
- $userManager->createUser($this->user1, 'pass');
- $userManager->createUser($this->user2, 'pass');
- \OC::registerShareHooks(\OC::$server->getSystemConfig());
- $this->job = Server::get(DeleteOrphanedSharesJob::class);
- }
- protected function tearDown(): void {
- $this->connection->executeUpdate('DELETE FROM `*PREFIX*share`');
- $userManager = \OC::$server->getUserManager();
- $user1 = $userManager->get($this->user1);
- if ($user1) {
- $user1->delete();
- }
- $user2 = $userManager->get($this->user2);
- if ($user2) {
- $user2->delete();
- }
- $this->logout();
- parent::tearDown();
- }
- private function getShares() {
- $shares = [];
- $result = $this->connection->executeQuery('SELECT * FROM `*PREFIX*share`');
- while ($row = $result->fetch()) {
- $shares[] = $row;
- }
- $result->closeCursor();
- return $shares;
- }
- /**
- * Test clearing orphaned shares
- */
- public function testClearShares(): void {
- $this->loginAsUser($this->user1);
- $user1Folder = \OC::$server->getUserFolder($this->user1);
- $testFolder = $user1Folder->newFolder('test');
- $testSubFolder = $testFolder->newFolder('sub');
- $shareManager = \OC::$server->getShareManager();
- $share = $shareManager->newShare();
- $share->setNode($testSubFolder)
- ->setShareType(IShare::TYPE_USER)
- ->setPermissions(Constants::PERMISSION_READ)
- ->setSharedWith($this->user2)
- ->setSharedBy($this->user1);
- $shareManager->createShare($share);
- $this->assertCount(1, $this->getShares());
- $this->job->run([]);
- $this->assertCount(1, $this->getShares(), 'Linked shares not deleted');
- $testFolder->delete();
- $this->job->run([]);
- $this->assertCount(0, $this->getShares(), 'Orphaned shares deleted');
- }
- }
|