Proyectos de Subversion Moodle

Rev

Rev 1 | | Comparar con el anterior | Ultima modificación | Ver Log |

Rev Autor Línea Nro. Línea
1 efrain 1
<?php
2
// This file is part of Moodle - http://moodle.org/
3
//
4
// Moodle is free software: you can redistribute it and/or modify
5
// it under the terms of the GNU General Public License as published by
6
// the Free Software Foundation, either version 3 of the License, or
7
// (at your option) any later version.
8
//
9
// Moodle is distributed in the hope that it will be useful,
10
// but WITHOUT ANY WARRANTY; without even the implied warranty of
11
// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
12
// GNU General Public License for more details.
13
//
14
// You should have received a copy of the GNU General Public License
15
// along with Moodle.  If not, see <http://www.gnu.org/licenses/>.
16
 
17
namespace tool_mfa;
18
 
19
/**
20
 * Tests for plugininfo.
21
 *
22
 * @package     tool_mfa
23
 * @author      Peter Burnett <peterburnett@catalyst-au.net>
24
 * @copyright   Catalyst IT
25
 * @license     http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later
26
 */
27
class plugininfo_factor_test extends \advanced_testcase {
28
 
29
    /**
30
     * Tests getting next user factor
31
     *
32
     * @covers ::get_next_user_login_factor
33
     * @covers ::setup_user_factor
34
     * @covers ::get_enabled_factors
35
     * @covers ::is_enabled
36
     * @covers ::has_setup
37
     * @covers ::get_active_user_factor_types
38
     */
11 efrain 39
    public function test_get_next_user_login_factor(): void {
1 efrain 40
 
41
        $this->resetAfterTest(true);
42
 
43
        // Create and login a user.
44
        $user = $this->getDataGenerator()->create_user();
45
        $this->setUser($user);
46
 
47
        // Test that with no enabled factors, fallback is returned.
48
        $this->assertEquals('fallback', \tool_mfa\plugininfo\factor::get_next_user_login_factor()->name);
49
 
50
        // Setup enabled totp factor for user.
51
        set_config('enabled', 1, 'factor_totp');
52
        $totpfactor = \tool_mfa\plugininfo\factor::get_factor('totp');
53
        $totpdata = [
54
            'secret' => 'fakekey',
55
            'devicename' => 'fakedevice',
56
        ];
57
        $this->assertNotEmpty($totpfactor->setup_user_factor((object) $totpdata));
58
 
59
        // Test that factor now appears (from STATE_UNKNOWN).
60
        $this->assertEquals('totp', \tool_mfa\plugininfo\factor::get_next_user_login_factor()->name);
61
 
62
        // Now pass this factor, check for fallback.
63
        $totpfactor->set_state(\tool_mfa\plugininfo\factor::STATE_PASS);
64
        $this->assertEquals('fallback', \tool_mfa\plugininfo\factor::get_next_user_login_factor()->name);
65
 
66
        // Add in a no-input factor.
67
        set_config('enabled', 1, 'factor_auth');
68
        $this->assertEquals(2, count(\tool_mfa\plugininfo\factor::get_enabled_factors()));
69
 
70
        $authfactor = \tool_mfa\plugininfo\factor::get_factor('auth');
71
        $this->assertTrue($authfactor->is_enabled());
72
        $this->assertFalse($authfactor->has_setup());
73
 
74
        // Check that the next factor is still the fallback factor.
75
        $this->assertEquals(2, count(\tool_mfa\plugininfo\factor::get_active_user_factor_types()));
76
        $this->assertEquals('fallback', \tool_mfa\plugininfo\factor::get_next_user_login_factor()->name);
77
    }
78
 
79
    /**
80
     * Tests if a user has more than one active factor.
81
     *
82
     * @covers ::user_has_more_than_one_active_factors
83
     */
84
    public function test_user_has_more_than_one_active_factors(): void {
85
        global $DB;
86
 
87
        $this->resetAfterTest(true);
88
 
89
        // Create a user.
90
        $user = $this->getDataGenerator()->create_user();
91
        $this->setUser($user);
92
 
93
        // Create two active user factors.
94
        set_config('enabled', 1, 'factor_totp');
95
        set_config('enabled', 1, 'factor_webauthn');
96
 
97
        $data = new \stdClass();
98
        $data->userid = $user->id;
99
        $data->factor = 'totp';
100
        $data->label = 'testtotp';
101
        $data->revoked = 0;
102
        $DB->insert_record('tool_mfa', $data);
103
 
104
        $data = new \stdClass();
105
        $data->userid = $user->id;
106
        $data->factor = 'webauthn';
107
        $data->label = 'testwebauthn';
108
        $data->revoked = 0;
109
        $factorid = $DB->insert_record('tool_mfa', $data);
110
 
111
        // Test there is more than one active factor.
112
        $hasmorethanonefactor = \tool_mfa\plugininfo\factor::user_has_more_than_one_active_factors();
113
        $this->assertTrue($hasmorethanonefactor);
114
 
115
        // Revoke a factor.
116
        $DB->set_field('tool_mfa', 'revoked', 1, ['id' => $factorid]);
117
 
118
        // There should no longer be more than one active factor.
119
        $hasmorethanonefactor = \tool_mfa\plugininfo\factor::user_has_more_than_one_active_factors();
120
        $this->assertFalse($hasmorethanonefactor);
121
    }
122
}