Passed
Pull Request — master (#165)
by Garion
02:22
created

testAccountResetTokenIsGeneratedAndStored()   A

Complexity

Conditions 1
Paths 1

Size

Total Lines 13
Code Lines 6

Duplication

Lines 0
Ratio 0 %

Importance

Changes 0
Metric Value
cc 1
eloc 6
nc 1
nop 0
dl 0
loc 13
rs 10
c 0
b 0
f 0
1
<?php
2
3
namespace SilverStripe\MFA\Tests\Extension\AccountReset;
4
5
use SilverStripe\Dev\SapphireTest;
6
use SilverStripe\MFA\Extension\AccountReset\MemberExtension;
7
use SilverStripe\Security\Member;
8
9
class MemberExtensionTest extends SapphireTest
10
{
11
    protected static $fixture_file = 'MemberExtensionTest.yml';
12
13
    public function testAccountResetTokenIsGeneratedAndStored()
14
    {
15
        /** @var Member&MemberExtension $member */
16
        $member = $this->objFromFixture(Member::class, 'user');
17
18
        $token = $member->generateAccountResetTokenAndStoreHash();
19
20
        // Refresh to ensure the changes have been stored
21
        $member = Member::get()->byID($member->ID);
22
23
        $this->assertNotEmpty($token);
24
        $this->assertNotEmpty($member->AccountResetHash);
25
        $this->assertNotEmpty($member->AccountResetExpired);
26
    }
27
28
    public function testGeneratedTokenCanBeVerified()
29
    {
30
        /** @var Member&MemberExtension $member */
31
        $member = $this->objFromFixture(Member::class, 'user');
32
33
        $token = $member->generateAccountResetTokenAndStoreHash();
34
35
        $this->assertTrue($member->verifyAccountResetToken($token));
36
        $this->assertFalse($member->verifyAccountResetToken('BADTOKEN'));
37
    }
38
}
39