blob: 23cb21f75d6cb0bf7acbffce3af4fcbd3a3a6035 (
plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
|
<?php
declare(strict_types=1);
/**
* SPDX-FileCopyrightText: 2018 Nextcloud GmbH and Nextcloud contributors
* SPDX-License-Identifier: AGPL-3.0-or-later
*/
namespace Core\Command\TwoFactorAuth;
use OC\Core\Command\TwoFactorAuth\State;
use OCP\Authentication\TwoFactorAuth\IRegistry;
use OCP\IUser;
use OCP\IUserManager;
use PHPUnit\Framework\MockObject\MockObject;
use Symfony\Component\Console\Tester\CommandTester;
use Test\TestCase;
class StateTest extends TestCase {
/** @var IRegistry|MockObject */
private $registry;
/** @var IUserManager|MockObject */
private $userManager;
/** @var CommandTester|MockObject */
private $cmd;
protected function setUp(): void {
parent::setUp();
$this->registry = $this->createMock(IRegistry::class);
$this->userManager = $this->createMock(IUserManager::class);
$cmd = new State($this->registry, $this->userManager);
$this->cmd = new CommandTester($cmd);
}
public function testWrongUID() {
$this->cmd->execute([
'uid' => 'nope',
]);
$output = $this->cmd->getDisplay();
$this->assertStringContainsString("Invalid UID", $output);
}
public function testStateNoProvidersActive() {
$user = $this->createMock(IUser::class);
$this->userManager->expects($this->once())
->method('get')
->with('eldora')
->willReturn($user);
$states = [
'u2f' => false,
'totp' => false,
];
$this->registry->expects($this->once())
->method('getProviderStates')
->with($user)
->willReturn($states);
$this->cmd->execute([
'uid' => 'eldora',
]);
$output = $this->cmd->getDisplay();
$this->assertStringContainsString("Two-factor authentication is not enabled for user eldora", $output);
}
public function testStateOneProviderActive() {
$user = $this->createMock(IUser::class);
$this->userManager->expects($this->once())
->method('get')
->with('mohamed')
->willReturn($user);
$states = [
'u2f' => true,
'totp' => false,
];
$this->registry->expects($this->once())
->method('getProviderStates')
->with($user)
->willReturn($states);
$this->cmd->execute([
'uid' => 'mohamed',
]);
$output = $this->cmd->getDisplay();
$this->assertStringContainsString("Two-factor authentication is enabled for user mohamed", $output);
}
}
|