request = $this->createMock(IRequest::class); $this->session = $this->createMock(ISession::class); $this->urlGenerator = $this->createMock(IURLGenerator::class); $this->controller = $this->getMockBuilder(AuthPublicShareController::class) ->setConstructorArgs([ 'app', $this->request, $this->session, $this->urlGenerator ])->onlyMethods([ 'authFailed', 'getPasswordHash', 'isAuthenticated', 'isPasswordProtected', 'isValidToken', 'showShare', 'verifyPassword', 'validateIdentity', 'generatePassword' ])->getMock(); } public function testShowAuthenticate(): void { $expects = new TemplateResponse('core', 'publicshareauth', [], 'guest'); $this->assertEquals($expects, $this->controller->showAuthenticate()); } public function testAuthenticateAuthenticated(): void { $this->controller->method('isAuthenticated') ->willReturn(true); $this->controller->setToken('myToken'); $this->session->method('get') ->willReturnMap([ ['public_link_authenticate_redirect', json_encode(['foo' => 'bar'])], ]); $this->urlGenerator->method('linkToRoute') ->willReturn('myLink!'); $result = $this->controller->authenticate('password'); $this->assertInstanceOf(RedirectResponse::class, $result); $this->assertSame('myLink!', $result->getRedirectURL()); } public function testAuthenticateInvalidPassword(): void { $this->controller->setToken('token'); $this->controller->method('isPasswordProtected') ->willReturn(true); $this->controller->method('verifyPassword') ->with('password') ->willReturn(false); $this->controller->expects($this->once()) ->method('authFailed'); $expects = new TemplateResponse('core', 'publicshareauth', ['wrongpw' => true], 'guest'); $expects->throttle(); $result = $this->controller->authenticate('password'); $this->assertEquals($expects, $result); } public function testAuthenticateValidPassword(): void { $this->controller->setToken('token'); $this->controller->method('isPasswordProtected') ->willReturn(true); $this->controller->method('verifyPassword') ->with('password') ->willReturn(true); $this->controller->method('getPasswordHash') ->willReturn('hash'); $this->session->expects($this->once()) ->method('regenerateId'); $this->session->method('get') ->willReturnMap([ ['public_link_authenticate_redirect', json_encode(['foo' => 'bar'])], ]); $tokenStored = false; $this->session ->method('set') ->willReturnCallback(function ($key, $value) use (&$tokenStored) { if ($key === AuthPublicShareController::DAV_AUTHENTICATED_FRONTEND) { $decoded = json_decode($value, true); if (isset($decoded['token']) && $decoded['token'] === 'hash') { $tokenStored = true; } return true; } return false; }); $this->urlGenerator->method('linkToRoute') ->willReturn('myLink!'); $result = $this->controller->authenticate('password'); $this->assertInstanceOf(RedirectResponse::class, $result); $this->assertSame('myLink!', $result->getRedirectURL()); $this->assertTrue($tokenStored); } }