2020-04-09 12:50:14 +03:00
|
|
|
<?php
|
|
|
|
|
|
|
|
declare(strict_types=1);
|
2018-05-22 09:52:16 +03:00
|
|
|
|
|
|
|
/**
|
|
|
|
* @copyright 2018 Christoph Wurst <christoph@winzerhof-wurst.at>
|
|
|
|
*
|
|
|
|
* @author 2018 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/>.
|
|
|
|
*
|
|
|
|
*/
|
|
|
|
|
|
|
|
namespace Test\Authentication\TwoFactorAuth;
|
|
|
|
|
|
|
|
use OC\Authentication\TwoFactorAuth\Db\ProviderUserAssignmentDao;
|
|
|
|
use OC\Authentication\TwoFactorAuth\Registry;
|
|
|
|
use OCP\Authentication\TwoFactorAuth\IProvider;
|
2018-09-29 21:56:23 +03:00
|
|
|
use OCP\Authentication\TwoFactorAuth\IRegistry;
|
|
|
|
use OCP\Authentication\TwoFactorAuth\RegistryEvent;
|
2019-09-10 12:37:53 +03:00
|
|
|
use OCP\EventDispatcher\IEventDispatcher;
|
2018-05-22 09:52:16 +03:00
|
|
|
use OCP\IUser;
|
2019-09-10 12:37:53 +03:00
|
|
|
use PHPUnit\Framework\MockObject\MockObject;
|
2018-05-22 09:52:16 +03:00
|
|
|
use Test\TestCase;
|
|
|
|
|
|
|
|
class RegistryTest extends TestCase {
|
|
|
|
|
2019-09-10 12:37:53 +03:00
|
|
|
/** @var ProviderUserAssignmentDao|MockObject */
|
2018-05-22 09:52:16 +03:00
|
|
|
private $dao;
|
|
|
|
|
2019-09-10 12:37:53 +03:00
|
|
|
/** @var IEventDispatcher|MockObject */
|
|
|
|
private $dispatcher;
|
|
|
|
|
2018-05-22 09:52:16 +03:00
|
|
|
/** @var Registry */
|
|
|
|
private $registry;
|
|
|
|
|
2019-11-21 18:40:38 +03:00
|
|
|
protected function setUp(): void {
|
2018-05-22 09:52:16 +03:00
|
|
|
parent::setUp();
|
|
|
|
|
|
|
|
$this->dao = $this->createMock(ProviderUserAssignmentDao::class);
|
2019-09-10 12:37:53 +03:00
|
|
|
$this->dispatcher = $this->createMock(IEventDispatcher::class);
|
2018-05-22 09:52:16 +03:00
|
|
|
|
2018-09-29 21:56:23 +03:00
|
|
|
$this->registry = new Registry($this->dao, $this->dispatcher);
|
2018-05-22 09:52:16 +03:00
|
|
|
}
|
|
|
|
|
|
|
|
public function testGetProviderStates() {
|
|
|
|
$user = $this->createMock(IUser::class);
|
|
|
|
$user->expects($this->once())->method('getUID')->willReturn('user123');
|
|
|
|
$state = [
|
|
|
|
'twofactor_totp' => true,
|
|
|
|
];
|
|
|
|
$this->dao->expects($this->once())->method('getState')->willReturn($state);
|
|
|
|
|
|
|
|
$actual = $this->registry->getProviderStates($user);
|
|
|
|
|
|
|
|
$this->assertEquals($state, $actual);
|
|
|
|
}
|
|
|
|
|
|
|
|
public function testEnableProvider() {
|
|
|
|
$user = $this->createMock(IUser::class);
|
|
|
|
$provider = $this->createMock(IProvider::class);
|
|
|
|
$user->expects($this->once())->method('getUID')->willReturn('user123');
|
|
|
|
$provider->expects($this->once())->method('getId')->willReturn('p1');
|
|
|
|
$this->dao->expects($this->once())->method('persist')->with('p1', 'user123',
|
|
|
|
true);
|
|
|
|
|
2018-09-29 21:56:23 +03:00
|
|
|
$this->dispatcher->expects($this->once())
|
|
|
|
->method('dispatch')
|
|
|
|
->with(
|
|
|
|
$this->equalTo(IRegistry::EVENT_PROVIDER_ENABLED),
|
2020-04-09 14:53:40 +03:00
|
|
|
$this->callback(function (RegistryEvent $e) use ($user, $provider) {
|
2018-09-29 21:56:23 +03:00
|
|
|
return $e->getUser() === $user && $e->getProvider() === $provider;
|
|
|
|
})
|
|
|
|
);
|
|
|
|
|
2018-05-22 09:52:16 +03:00
|
|
|
$this->registry->enableProviderFor($provider, $user);
|
|
|
|
}
|
|
|
|
|
|
|
|
public function testDisableProvider() {
|
|
|
|
$user = $this->createMock(IUser::class);
|
|
|
|
$provider = $this->createMock(IProvider::class);
|
|
|
|
$user->expects($this->once())->method('getUID')->willReturn('user123');
|
|
|
|
$provider->expects($this->once())->method('getId')->willReturn('p1');
|
|
|
|
$this->dao->expects($this->once())->method('persist')->with('p1', 'user123',
|
|
|
|
false);
|
|
|
|
|
2018-09-29 21:56:23 +03:00
|
|
|
|
|
|
|
$this->dispatcher->expects($this->once())
|
|
|
|
->method('dispatch')
|
|
|
|
->with(
|
|
|
|
$this->equalTo(IRegistry::EVENT_PROVIDER_DISABLED),
|
2020-04-09 14:53:40 +03:00
|
|
|
$this->callback(function (RegistryEvent $e) use ($user, $provider) {
|
2018-09-29 21:56:23 +03:00
|
|
|
return $e->getUser() === $user && $e->getProvider() === $provider;
|
|
|
|
})
|
|
|
|
);
|
|
|
|
|
2018-05-22 09:52:16 +03:00
|
|
|
$this->registry->disableProviderFor($provider, $user);
|
|
|
|
}
|
|
|
|
|
2020-01-08 12:51:44 +03:00
|
|
|
public function testDeleteUserData() {
|
|
|
|
$user = $this->createMock(IUser::class);
|
|
|
|
$user->expects($this->once())->method('getUID')->willReturn('user123');
|
|
|
|
$this->dao->expects($this->once())
|
|
|
|
->method('deleteByUser')
|
|
|
|
->with('user123');
|
|
|
|
|
|
|
|
$this->registry->deleteUserData($user);
|
|
|
|
}
|
|
|
|
|
2018-09-10 18:02:37 +03:00
|
|
|
public function testCleanUp() {
|
|
|
|
$this->dao->expects($this->once())
|
|
|
|
->method('deleteAll')
|
|
|
|
->with('twofactor_u2f');
|
|
|
|
|
|
|
|
$this->registry->cleanUp('twofactor_u2f');
|
|
|
|
}
|
2018-05-22 09:52:16 +03:00
|
|
|
}
|