keyManagerMock->expects($this->exactly(2)) ->method('recoveryKeyExists') ->willReturnOnConsecutiveCalls(false, true); $this->cryptMock->expects($this->once()) ->method('createKeyPair') ->willReturn([ 'publicKey' => 'privateKey', 'privateKey' => 'publicKey', ]); $this->keyManagerMock->expects($this->once()) ->method('setRecoveryKey') ->willReturn(false); $this->keyManagerMock->expects($this->exactly(2)) ->method('checkRecoveryPassword') ->willReturnOnConsecutiveCalls(true, true); $this->assertTrue($this->instance->enableAdminRecovery('password')); $this->assertArrayHasKey('recoveryAdminEnabled', self::$tempStorage); $this->assertEquals(1, self::$tempStorage['recoveryAdminEnabled']); $this->assertTrue($this->instance->enableAdminRecovery('password')); } public function testEnableAdminRecoveryCouldNotCheckPassword() { $this->keyManagerMock->expects($this->exactly(2)) ->method('recoveryKeyExists') ->willReturnOnConsecutiveCalls(false, true); $this->cryptMock->expects($this->once()) ->method('createKeyPair') ->willReturn([ 'publicKey' => 'privateKey', 'privateKey' => 'publicKey', ]); $this->keyManagerMock->expects($this->once()) ->method('setRecoveryKey') ->willReturn(false); $this->keyManagerMock->expects($this->exactly(2)) ->method('checkRecoveryPassword') ->willReturnOnConsecutiveCalls(true, false); $this->assertTrue($this->instance->enableAdminRecovery('password')); $this->assertArrayHasKey('recoveryAdminEnabled', self::$tempStorage); $this->assertEquals(1, self::$tempStorage['recoveryAdminEnabled']); $this->assertFalse($this->instance->enableAdminRecovery('password')); } public function testEnableAdminRecoveryCouldNotCreateKey() { $this->keyManagerMock->expects($this->once()) ->method('recoveryKeyExists') ->willReturn(false); $this->cryptMock->expects($this->once()) ->method('createKeyPair') ->willReturn(false); $this->assertFalse($this->instance->enableAdminRecovery('password')); } public function testChangeRecoveryKeyPasswordSuccessful() { $this->assertFalse($this->instance->changeRecoveryKeyPassword('password', 'passwordOld')); $this->keyManagerMock->expects($this->once()) ->method('getSystemPrivateKey'); $this->cryptMock->expects($this->once()) ->method('decryptPrivateKey'); $this->cryptMock->expects($this->once()) ->method('encryptPrivateKey') ->willReturn(true); $this->assertTrue($this->instance->changeRecoveryKeyPassword('password', 'passwordOld')); } public function testChangeRecoveryKeyPasswordCouldNotDecryptPrivateRecoveryKey() { $this->assertFalse($this->instance->changeRecoveryKeyPassword('password', 'passwordOld')); $this->keyManagerMock->expects($this->once()) ->method('getSystemPrivateKey'); $this->cryptMock->expects($this->once()) ->method('decryptPrivateKey') ->willReturn(false); $this->assertFalse($this->instance->changeRecoveryKeyPassword('password', 'passwordOld')); } public function testDisableAdminRecovery() { $this->keyManagerMock->expects($this->exactly(2)) ->method('checkRecoveryPassword') ->willReturnOnConsecutiveCalls(true, false); $this->assertArrayHasKey('recoveryAdminEnabled', self::$tempStorage); $this->assertTrue($this->instance->disableAdminRecovery('password')); $this->assertEquals(0, self::$tempStorage['recoveryAdminEnabled']); $this->assertFalse($this->instance->disableAdminRecovery('password')); } public function testIsRecoveryEnabledForUser() { $this->configMock->expects($this->exactly(2)) ->method('getUserValue') ->willReturnOnConsecutiveCalls('1', '0'); $this->assertTrue($this->instance->isRecoveryEnabledForUser()); $this->assertFalse($this->instance->isRecoveryEnabledForUser('admin')); } public function testIsRecoveryKeyEnabled() { $this->assertFalse($this->instance->isRecoveryKeyEnabled()); self::$tempStorage['recoveryAdminEnabled'] = '1'; $this->assertTrue($this->instance->isRecoveryKeyEnabled()); } public function testSetRecoveryFolderForUser() { $this->viewMock->expects($this->exactly(2)) ->method('getDirectoryContent') ->willReturn([]); $this->assertTrue($this->instance->setRecoveryForUser(0)); $this->assertTrue($this->instance->setRecoveryForUser('1')); } public function testRecoverUserFiles() { $this->viewMock->expects($this->once()) ->method('getDirectoryContent') ->willReturn([]); $this->cryptMock->expects($this->once()) ->method('decryptPrivateKey') ->willReturn('privateKey'); $this->instance->recoverUsersFiles('password', 'admin'); $this->addToAssertionCount(1); } public function testRecoverFile() { $this->keyManagerMock->expects($this->once()) ->method('getEncryptedFileKey') ->willReturn(true); $this->keyManagerMock->expects($this->once()) ->method('getShareKey') ->willReturn(true); $this->cryptMock->expects($this->once()) ->method('multiKeyDecryptLegacy') ->willReturn('multiKeyDecryptLegacyResult'); $this->fileMock->expects($this->once()) ->method('getAccessList') ->willReturn(['users' => ['admin']]); $this->keyManagerMock->expects($this->once()) ->method('getPublicKey') ->willReturn('publicKey'); $this->keyManagerMock->expects($this->once()) ->method('addSystemKeys') ->with($this->anything(), $this->anything(), $this->equalTo('admin')) ->willReturn(['admin' => 'publicKey']); $this->cryptMock->expects($this->once()) ->method('multiKeyEncrypt') ->willReturn(['admin' => 'shareKey']); $this->keyManagerMock->expects($this->once()) ->method('deleteLegacyFileKey'); $this->keyManagerMock->expects($this->once()) ->method('setShareKey'); $this->assertNull(self::invokePrivate($this->instance, 'recoverFile', ['/', 'testkey', 'admin'])); } protected function setUp(): void { parent::setUp(); $this->user = $this->createMock(IUser::class); $this->user->expects($this->any()) ->method('getUID') ->willReturn('admin'); $this->userSessionMock = $this->createMock(IUserSession::class); $this->userSessionMock->expects($this->any()) ->method('getUser') ->willReturn($this->user); $this->userSessionMock->expects($this->any()) ->method('isLoggedIn') ->willReturn(true); $this->cryptMock = $this->getMockBuilder(Crypt::class)->disableOriginalConstructor()->getMock(); $this->keyManagerMock = $this->getMockBuilder(KeyManager::class)->disableOriginalConstructor()->getMock(); $this->configMock = $this->createMock(IConfig::class); $this->fileMock = $this->createMock(IFile::class); $this->viewMock = $this->createMock(View::class); $this->configMock->expects($this->any()) ->method('setAppValue') ->willReturnCallback([$this, 'setValueTester']); $this->configMock->expects($this->any()) ->method('getAppValue') ->willReturnCallback([$this, 'getValueTester']); $this->instance = new Recovery($this->userSessionMock, $this->cryptMock, $this->keyManagerMock, $this->configMock, $this->fileMock, $this->viewMock); } /** * @param $app * @param $key * @param $value */ public function setValueTester($app, $key, $value) { self::$tempStorage[$key] = $value; } /** * @param $key */ public function removeValueTester($key) { unset(self::$tempStorage[$key]); } /** * @param $app * @param $key * @return mixed */ public function getValueTester($app, $key) { if (!empty(self::$tempStorage[$key])) { return self::$tempStorage[$key]; } return null; } }