Passed
Pull Request — master (#13)
by Simon
01:55
created

YubikeyAuthProviderTest::setUp()   A

Complexity

Conditions 1
Paths 1

Size

Total Lines 5
Code Lines 2

Duplication

Lines 0
Ratio 0 %

Importance

Changes 0
Metric Value
dl 0
loc 5
rs 9.4285
c 0
b 0
f 0
cc 1
eloc 2
nc 1
nop 0
1
<?php
2
3
namespace Firesphere\YubiAuth\Tests;
4
5
use Firesphere\YubiAuth\Providers\YubikeyAuthProvider;
6
use SilverStripe\Core\Config\Config;
7
use SilverStripe\Core\Injector\Injector;
8
use SilverStripe\Dev\SapphireTest;
9
use SilverStripe\ORM\ValidationResult;
10
use SilverStripe\Security\Member;
11
12
class YubikeyAuthProviderTest extends SapphireTest
13
{
14
    protected static $fixture_file = '../fixtures/Member.yml';
15
16
    /**
17
     * @var YubikeyAuthProvider
18
     */
19
    protected $provider;
20
21
    public function testCheckNoYubikeyDaysZero()
22
    {
23
        Config::modify()->set(YubikeyAuthProvider::class, 'MaxNoYubiLoginDays', 0);
24
        /** @var Member $member */
25
        $member = Member::get()->filter(['Email' => '[email protected]'])->first();
26
        $member->Created = date('Y-m-d', strtotime('-1 year'));
27
        $member->YubiAuthEnabled = false;
28
        $member->write();
29
30
        $result = $this->provider->checkNoYubiDays($member);
31
        $this->assertInstanceOf(Member::class, $result);
32
    }
33
34
    public function testCheckNoYubikeyDaysError()
35
    {
36
        /** @var Member $member */
37
        $member = Member::get()->filter(['Email' => '[email protected]'])->first();
38
        $member->Created = date('Y-m-d', strtotime('-1 year'));
39
        $member->YubiAuthEnabled = false;
40
        $member->write();
41
42
        $result = $this->provider->checkNoYubiDays($member);
43
        $this->assertInstanceOf(ValidationResult::class, $result);
44
    }
45
46
    public function testvalidateTokenDuplicate()
47
    {
48
        $member1 = Member::create(['Email' => '[email protected]', 'Yubikey' => '1234567890']);
49
        $member1->write();
50
        $member2 = Member::create(['Email' => '[email protected]', 'Yubikey' => '1234567890']);
51
        $member2->write();
52
53
        $result = $this->provider->validateToken($member1, '1234567890');
54
55
        $this->assertInstanceOf(ValidationResult::class, $result);
56
        $this->assertFalse($result->isValid());
57
    }
58
59
    public function testvalidateTokenID()
60
    {
61
        $member1 = Member::create(['Email' => '[email protected]', 'Yubikey' => '0987654321']);
62
        $member1->write();
63
        $member2 = Member::create(['Email' => '[email protected]', 'Yubikey' => '1234567890']);
64
        $member2->write();
65
66
        $result = $this->provider->validateToken($member1, '1234567890');
67
68
        $this->assertInstanceOf(ValidationResult::class, $result);
69
        $this->assertFalse($result->isValid());
70
    }
71
72
    public function testvalidateTokenNotMatchesMember()
73
    {
74
        $member1 = Member::create(['Email' => '[email protected]', 'Yubikey' => '0987654321']);
75
        $member1->write();
76
77
        $result = $this->provider->validateToken($member1, '12344567890');
78
79
        $this->assertInstanceOf(ValidationResult::class, $result);
80
        $this->assertFalse($result->isValid());
81
    }
82
83
    public function testvalidateTokenUnique()
84
    {
85
        $member1 = Member::create(['Email' => '[email protected]', 'Yubikey' => 'abcdefghij']);
86
        $member1->write();
87
        $member2 = Member::create(['Email' => '[email protected]', 'Yubikey' => '1234567890']);
88
        $member2->write();
89
90
        $result = $this->provider->validateToken($member1, 'abcdefghij');
91
92
        $this->assertInstanceOf(ValidationResult::class, $result);
93
        $this->assertTrue($result->isValid());
94
    }
95
96
    protected function setUp()
97
    {
98
        $this->provider = Injector::inst()->get(YubikeyAuthProvider::class);
99
100
        return parent::setUp();
101
    }
102
}
103