Passed
Pull Request — master (#127)
by Garion
02:33
created

testAdminUserCanViewButNotEditOthersMFAConfig()   A

Complexity

Conditions 1
Paths 1

Size

Total Lines 8
Code Lines 4

Duplication

Lines 0
Ratio 0 %

Importance

Changes 0
Metric Value
eloc 4
dl 0
loc 8
rs 10
c 0
b 0
f 0
cc 1
nc 1
nop 0
1
<?php
2
3
namespace SilverStripe\MFA\Tests\Extension;
4
5
use SilverStripe\Dev\SapphireTest;
6
use SilverStripe\Security\Member;
7
8
class MemberMFAExtensionTest extends SapphireTest
9
{
10
    protected static $fixture_file = 'MemberMFAExtensionTest.yml';
11
12
    public function testAdminUserCanViewButNotEditOthersMFAConfig()
13
    {
14
        $targetMember = $this->objFromFixture(Member::class, 'squib');
15
16
        $this->logInAs('admin');
17
18
        $this->assertTrue($targetMember->currentUserCanViewMFAConfig(), 'Can View');
19
        $this->assertFalse($targetMember->currentUserCanEditMFAConfig(), 'Can Edit');
20
    }
21
22
    public function testAdminUserCanViewAndEditTheirOwnMFAConfig()
23
    {
24
        $targetMember = $this->objFromFixture(Member::class, 'admin');
25
26
        $this->logInAs($targetMember);
27
28
        $this->assertTrue($targetMember->currentUserCanViewMFAConfig(), 'Can View');
29
        $this->assertTrue($targetMember->currentUserCanEditMFAConfig(), 'Can Edit');
30
    }
31
32
    public function testStandardUserCannotViewOrEditOthersMFAConfig()
33
    {
34
        $targetMember = $this->objFromFixture(Member::class, 'admin');
35
36
        $this->logInAs('squib');
37
38
        $this->assertFalse($targetMember->currentUserCanViewMFAConfig(), 'Can View');
39
        $this->assertFalse($targetMember->currentUserCanEditMFAConfig(), 'Can Edit');
40
    }
41
42
    public function testStandardUserCanViewAndEditTheirOwnMFAConfig()
43
    {
44
        $targetMember = $this->objFromFixture(Member::class, 'squib');
45
46
        $this->logInAs($targetMember);
47
48
        $this->assertTrue($targetMember->currentUserCanViewMFAConfig(), 'Can View');
49
        $this->assertTrue($targetMember->currentUserCanEditMFAConfig(), 'Can Edit');
50
    }
51
}
52