123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357 |
- <?php
- /**
- * @copyright 2019 Christoph Wurst <christoph@winzerhof-wurst.at>
- *
- * @author 2019 Christoph Wurst <christoph@winzerhof-wurst.at>
- *
- * @license GNU AGPL version 3 or any later version
- *
- * This program is free software: you can redistribute it and/or modify
- * it under the terms of the GNU Affero General Public License as
- * published by the Free Software Foundation, either version 3 of the
- * License, or (at your option) any later version.
- *
- * This program is distributed in the hope that it will be useful,
- * but WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
- * GNU Affero General Public License for more details.
- *
- * You should have received a copy of the GNU Affero General Public License
- * along with this program. If not, see <http://www.gnu.org/licenses/>.
- */
- declare(strict_types=1);
- namespace Test\Authentication\Login;
- use OC\Authentication\Login\TwoFactorCommand;
- use OC\Authentication\TwoFactorAuth\Manager;
- use OC\Authentication\TwoFactorAuth\MandatoryTwoFactor;
- use OC\Authentication\TwoFactorAuth\ProviderSet;
- use OCP\Authentication\TwoFactorAuth\IActivatableAtLogin;
- use OCP\Authentication\TwoFactorAuth\IProvider as ITwoFactorAuthProvider;
- use OCP\IURLGenerator;
- use PHPUnit\Framework\MockObject\MockObject;
- class TwoFactorCommandTest extends ALoginCommandTest {
- /** @var Manager|MockObject */
- private $twoFactorManager;
- /** @var MandatoryTwoFactor|MockObject */
- private $mandatoryTwoFactor;
- /** @var IURLGenerator|MockObject */
- private $urlGenerator;
- protected function setUp(): void {
- parent::setUp();
- $this->twoFactorManager = $this->createMock(Manager::class);
- $this->mandatoryTwoFactor = $this->createMock(MandatoryTwoFactor::class);
- $this->urlGenerator = $this->createMock(IURLGenerator::class);
- $this->cmd = new TwoFactorCommand(
- $this->twoFactorManager,
- $this->mandatoryTwoFactor,
- $this->urlGenerator
- );
- }
- public function testNotTwoFactorAuthenticated() {
- $data = $this->getLoggedInLoginData();
- $this->twoFactorManager->expects($this->once())
- ->method('isTwoFactorAuthenticated')
- ->willReturn(false);
- $this->twoFactorManager->expects($this->never())
- ->method('prepareTwoFactorLogin');
- $result = $this->cmd->process($data);
- $this->assertTrue($result->isSuccess());
- }
- public function testProcessOneActiveProvider() {
- $data = $this->getLoggedInLoginData();
- $this->twoFactorManager->expects($this->once())
- ->method('isTwoFactorAuthenticated')
- ->willReturn(true);
- $this->twoFactorManager->expects($this->once())
- ->method('prepareTwoFactorLogin')
- ->with(
- $this->user,
- $data->isRememberLogin()
- );
- $provider = $this->createMock(ITwoFactorAuthProvider::class);
- $this->twoFactorManager->expects($this->once())
- ->method('getProviderSet')
- ->willReturn(new ProviderSet([
- $provider,
- ], false));
- $this->twoFactorManager->expects($this->once())
- ->method('getLoginSetupProviders')
- ->with($this->user)
- ->willReturn([]);
- $this->mandatoryTwoFactor->expects($this->any())
- ->method('isEnforcedFor')
- ->with($this->user)
- ->willReturn(false);
- $provider->expects($this->once())
- ->method('getId')
- ->willReturn('test');
- $this->urlGenerator->expects($this->once())
- ->method('linkToRoute')
- ->with(
- 'core.TwoFactorChallenge.showChallenge',
- [
- 'challengeProviderId' => 'test'
- ]
- )
- ->willReturn('two/factor/url');
- $result = $this->cmd->process($data);
- $this->assertTrue($result->isSuccess());
- $this->assertEquals('two/factor/url', $result->getRedirectUrl());
- }
- public function testProcessMissingProviders() {
- $data = $this->getLoggedInLoginData();
- $this->twoFactorManager->expects($this->once())
- ->method('isTwoFactorAuthenticated')
- ->willReturn(true);
- $this->twoFactorManager->expects($this->once())
- ->method('prepareTwoFactorLogin')
- ->with(
- $this->user,
- $data->isRememberLogin()
- );
- $provider = $this->createMock(ITwoFactorAuthProvider::class);
- $provider->expects($this->once())
- ->method('getId')
- ->willReturn('test1');
- $this->twoFactorManager->expects($this->once())
- ->method('getProviderSet')
- ->willReturn(new ProviderSet([
- $provider,
- ], true));
- $this->twoFactorManager->expects($this->once())
- ->method('getLoginSetupProviders')
- ->with($this->user)
- ->willReturn([]);
- $this->mandatoryTwoFactor->expects($this->any())
- ->method('isEnforcedFor')
- ->with($this->user)
- ->willReturn(false);
- $this->urlGenerator->expects($this->once())
- ->method('linkToRoute')
- ->with(
- 'core.TwoFactorChallenge.selectChallenge'
- )
- ->willReturn('two/factor/url');
- $result = $this->cmd->process($data);
- $this->assertTrue($result->isSuccess());
- $this->assertEquals('two/factor/url', $result->getRedirectUrl());
- }
- public function testProcessTwoActiveProviders() {
- $data = $this->getLoggedInLoginData();
- $this->twoFactorManager->expects($this->once())
- ->method('isTwoFactorAuthenticated')
- ->willReturn(true);
- $this->twoFactorManager->expects($this->once())
- ->method('prepareTwoFactorLogin')
- ->with(
- $this->user,
- $data->isRememberLogin()
- );
- $provider1 = $this->createMock(ITwoFactorAuthProvider::class);
- $provider2 = $this->createMock(ITwoFactorAuthProvider::class);
- $provider1->expects($this->once())
- ->method('getId')
- ->willReturn('test1');
- $provider2->expects($this->once())
- ->method('getId')
- ->willReturn('test2');
- $this->twoFactorManager->expects($this->once())
- ->method('getProviderSet')
- ->willReturn(new ProviderSet([
- $provider1,
- $provider2,
- ], false));
- $this->twoFactorManager->expects($this->once())
- ->method('getLoginSetupProviders')
- ->with($this->user)
- ->willReturn([]);
- $this->mandatoryTwoFactor->expects($this->any())
- ->method('isEnforcedFor')
- ->with($this->user)
- ->willReturn(false);
- $this->urlGenerator->expects($this->once())
- ->method('linkToRoute')
- ->with(
- 'core.TwoFactorChallenge.selectChallenge'
- )
- ->willReturn('two/factor/url');
- $result = $this->cmd->process($data);
- $this->assertTrue($result->isSuccess());
- $this->assertEquals('two/factor/url', $result->getRedirectUrl());
- }
- public function testProcessFailingProviderAndEnforcedButNoSetupProviders() {
- $data = $this->getLoggedInLoginData();
- $this->twoFactorManager->expects($this->once())
- ->method('isTwoFactorAuthenticated')
- ->willReturn(true);
- $this->twoFactorManager->expects($this->once())
- ->method('prepareTwoFactorLogin')
- ->with(
- $this->user,
- $data->isRememberLogin()
- );
- $this->twoFactorManager->expects($this->once())
- ->method('getProviderSet')
- ->willReturn(new ProviderSet([], true));
- $this->twoFactorManager->expects($this->once())
- ->method('getLoginSetupProviders')
- ->with($this->user)
- ->willReturn([]);
- $this->mandatoryTwoFactor->expects($this->any())
- ->method('isEnforcedFor')
- ->with($this->user)
- ->willReturn(true);
- $this->urlGenerator->expects($this->once())
- ->method('linkToRoute')
- ->with(
- 'core.TwoFactorChallenge.selectChallenge'
- )
- ->willReturn('two/factor/url');
- $result = $this->cmd->process($data);
- $this->assertTrue($result->isSuccess());
- $this->assertEquals('two/factor/url', $result->getRedirectUrl());
- }
- public function testProcessFailingProviderAndEnforced() {
- $data = $this->getLoggedInLoginData();
- $this->twoFactorManager->expects($this->once())
- ->method('isTwoFactorAuthenticated')
- ->willReturn(true);
- $this->twoFactorManager->expects($this->once())
- ->method('prepareTwoFactorLogin')
- ->with(
- $this->user,
- $data->isRememberLogin()
- );
- $provider = $this->createMock(IActivatableAtLogin::class);
- $this->twoFactorManager->expects($this->once())
- ->method('getProviderSet')
- ->willReturn(new ProviderSet([
- $provider,
- ], true));
- $this->twoFactorManager->expects($this->once())
- ->method('getLoginSetupProviders')
- ->with($this->user)
- ->willReturn([]);
- $this->mandatoryTwoFactor->expects($this->any())
- ->method('isEnforcedFor')
- ->with($this->user)
- ->willReturn(true);
- $this->urlGenerator->expects($this->once())
- ->method('linkToRoute')
- ->with(
- 'core.TwoFactorChallenge.selectChallenge'
- )
- ->willReturn('two/factor/url');
- $result = $this->cmd->process($data);
- $this->assertTrue($result->isSuccess());
- $this->assertEquals('two/factor/url', $result->getRedirectUrl());
- }
- public function testProcessNoProvidersButEnforced() {
- $data = $this->getLoggedInLoginData();
- $this->twoFactorManager->expects($this->once())
- ->method('isTwoFactorAuthenticated')
- ->willReturn(true);
- $this->twoFactorManager->expects($this->once())
- ->method('prepareTwoFactorLogin')
- ->with(
- $this->user,
- $data->isRememberLogin()
- );
- $this->twoFactorManager->expects($this->once())
- ->method('getProviderSet')
- ->willReturn(new ProviderSet([], false));
- $this->twoFactorManager->expects($this->once())
- ->method('getLoginSetupProviders')
- ->with($this->user)
- ->willReturn([]);
- $this->mandatoryTwoFactor->expects($this->any())
- ->method('isEnforcedFor')
- ->with($this->user)
- ->willReturn(true);
- $this->urlGenerator->expects($this->once())
- ->method('linkToRoute')
- ->with(
- 'core.TwoFactorChallenge.selectChallenge'
- )
- ->willReturn('two/factor/url');
- $result = $this->cmd->process($data);
- $this->assertTrue($result->isSuccess());
- $this->assertEquals('two/factor/url', $result->getRedirectUrl());
- }
- public function testProcessWithRedirectUrl() {
- $data = $this->getLoggedInLoginDataWithRedirectUrl();
- $this->twoFactorManager->expects($this->once())
- ->method('isTwoFactorAuthenticated')
- ->willReturn(true);
- $this->twoFactorManager->expects($this->once())
- ->method('prepareTwoFactorLogin')
- ->with(
- $this->user,
- $data->isRememberLogin()
- );
- $provider = $this->createMock(ITwoFactorAuthProvider::class);
- $this->twoFactorManager->expects($this->once())
- ->method('getProviderSet')
- ->willReturn(new ProviderSet([
- $provider,
- ], false));
- $this->twoFactorManager->expects($this->once())
- ->method('getLoginSetupProviders')
- ->with($this->user)
- ->willReturn([]);
- $this->mandatoryTwoFactor->expects($this->any())
- ->method('isEnforcedFor')
- ->with($this->user)
- ->willReturn(false);
- $provider->expects($this->once())
- ->method('getId')
- ->willReturn('test');
- $this->urlGenerator->expects($this->once())
- ->method('linkToRoute')
- ->with(
- 'core.TwoFactorChallenge.showChallenge',
- [
- 'challengeProviderId' => 'test',
- 'redirect_url' => $this->redirectUrl,
- ]
- )
- ->willReturn('two/factor/url');
- $result = $this->cmd->process($data);
- $this->assertTrue($result->isSuccess());
- $this->assertEquals('two/factor/url', $result->getRedirectUrl());
- }
- }
|