123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194 |
- <?php
- /**
- * SPDX-FileCopyrightText: 2016-2024 Nextcloud GmbH and Nextcloud contributors
- * SPDX-FileCopyrightText: 2016 ownCloud, Inc.
- * SPDX-License-Identifier: AGPL-3.0-only
- */
- namespace OCA\Files_External\Tests\Service;
- use OC\Files\Filesystem;
- use OCA\Files_External\Lib\StorageConfig;
- use OCA\Files_External\MountConfig;
- use OCA\Files_External\NotFoundException;
- use OCA\Files_External\Service\GlobalStoragesService;
- use OCA\Files_External\Service\StoragesService;
- use OCA\Files_External\Service\UserStoragesService;
- use OCP\IUserSession;
- use Test\Traits\UserTrait;
- /**
- * @group DB
- */
- class UserStoragesServiceTest extends StoragesServiceTest {
- use UserTrait;
- private $user;
- private $userId;
- /**
- * @var StoragesService
- */
- protected $globalStoragesService;
- protected function setUp(): void {
- parent::setUp();
- $this->globalStoragesService = new GlobalStoragesService($this->backendService, $this->dbConfig, $this->mountCache, $this->eventDispatcher);
- $this->userId = $this->getUniqueID('user_');
- $this->createUser($this->userId, $this->userId);
- $this->user = \OC::$server->getUserManager()->get($this->userId);
- /** @var IUserSession|\PHPUnit\Framework\MockObject\MockObject $userSession */
- $userSession = $this->createMock(IUserSession::class);
- $userSession
- ->expects($this->any())
- ->method('getUser')
- ->willReturn($this->user);
- $this->service = new UserStoragesService($this->backendService, $this->dbConfig, $userSession, $this->mountCache, $this->eventDispatcher);
- }
- private function makeTestStorageData() {
- return $this->makeStorageConfig([
- 'mountPoint' => 'mountpoint',
- 'backendIdentifier' => 'identifier:\OCA\Files_External\Lib\Backend\SMB',
- 'authMechanismIdentifier' => 'identifier:\Auth\Mechanism',
- 'backendOptions' => [
- 'option1' => 'value1',
- 'option2' => 'value2',
- 'password' => 'testPassword',
- ],
- 'mountOptions' => [
- 'preview' => false,
- ]
- ]);
- }
- public function testAddStorage(): void {
- $storage = $this->makeTestStorageData();
- $newStorage = $this->service->addStorage($storage);
- $id = $newStorage->getId();
- $newStorage = $this->service->getStorage($id);
- $this->assertEquals($storage->getMountPoint(), $newStorage->getMountPoint());
- $this->assertEquals($storage->getBackend(), $newStorage->getBackend());
- $this->assertEquals($storage->getAuthMechanism(), $newStorage->getAuthMechanism());
- $this->assertEquals($storage->getBackendOptions(), $newStorage->getBackendOptions());
- $this->assertEquals(0, $newStorage->getStatus());
- // hook called once for user
- $this->assertHookCall(
- current(self::$hookCalls),
- Filesystem::signal_create_mount,
- $storage->getMountPoint(),
- MountConfig::MOUNT_TYPE_USER,
- $this->userId
- );
- $nextStorage = $this->service->addStorage($storage);
- $this->assertEquals($id + 1, $nextStorage->getId());
- }
- public function testUpdateStorage(): void {
- $storage = $this->makeStorageConfig([
- 'mountPoint' => 'mountpoint',
- 'backendIdentifier' => 'identifier:\OCA\Files_External\Lib\Backend\SMB',
- 'authMechanismIdentifier' => 'identifier:\Auth\Mechanism',
- 'backendOptions' => [
- 'option1' => 'value1',
- 'option2' => 'value2',
- 'password' => 'testPassword',
- ],
- ]);
- $newStorage = $this->service->addStorage($storage);
- $backendOptions = $newStorage->getBackendOptions();
- $backendOptions['password'] = 'anotherPassword';
- $newStorage->setBackendOptions($backendOptions);
- self::$hookCalls = [];
- $newStorage = $this->service->updateStorage($newStorage);
- $this->assertEquals('anotherPassword', $newStorage->getBackendOptions()['password']);
- $this->assertEquals([$this->userId], $newStorage->getApplicableUsers());
- // these attributes are unused for user storages
- $this->assertEmpty($newStorage->getApplicableGroups());
- $this->assertEquals(0, $newStorage->getStatus());
- // no hook calls
- $this->assertEmpty(self::$hookCalls);
- }
- /**
- * @dataProvider deleteStorageDataProvider
- */
- public function testDeleteStorage($backendOptions, $rustyStorageId): void {
- parent::testDeleteStorage($backendOptions, $rustyStorageId);
- // hook called once for user (first one was during test creation)
- $this->assertHookCall(
- self::$hookCalls[1],
- Filesystem::signal_delete_mount,
- '/mountpoint',
- MountConfig::MOUNT_TYPE_USER,
- $this->userId
- );
- }
- public function testHooksRenameMountPoint(): void {
- $storage = $this->makeTestStorageData();
- $storage = $this->service->addStorage($storage);
- $storage->setMountPoint('renamedMountpoint');
- // reset calls
- self::$hookCalls = [];
- $this->service->updateStorage($storage);
- // hook called twice
- $this->assertHookCall(
- self::$hookCalls[0],
- Filesystem::signal_delete_mount,
- '/mountpoint',
- MountConfig::MOUNT_TYPE_USER,
- $this->userId
- );
- $this->assertHookCall(
- self::$hookCalls[1],
- Filesystem::signal_create_mount,
- '/renamedMountpoint',
- MountConfig::MOUNT_TYPE_USER,
- $this->userId
- );
- }
- public function testGetAdminStorage(): void {
- $this->expectException(NotFoundException::class);
- $backend = $this->backendService->getBackend('identifier:\OCA\Files_External\Lib\Backend\SMB');
- $authMechanism = $this->backendService->getAuthMechanism('identifier:\Auth\Mechanism');
- $storage = new StorageConfig();
- $storage->setMountPoint('mountpoint');
- $storage->setBackend($backend);
- $storage->setAuthMechanism($authMechanism);
- $storage->setBackendOptions(['password' => 'testPassword']);
- $storage->setApplicableUsers([$this->userId]);
- $newStorage = $this->globalStoragesService->addStorage($storage);
- $this->assertInstanceOf('\OCA\Files_External\Lib\StorageConfig', $this->globalStoragesService->getStorage($newStorage->getId()));
- $this->service->getStorage($newStorage->getId());
- }
- }
|