Failed Conditions
Pull Request — master (#13)
by Adrien
05:33 queued 02:11
created

AclTest.php$0 ➔ testIsCurrentUserAllowed()   A

Complexity

Conditions 1

Size

Total Lines 38

Duplication

Lines 0
Ratio 0 %

Importance

Changes 0
Metric Value
cc 1
c 0
b 0
f 0
dl 0
loc 38
rs 9.312

1 Method

Rating   Name   Duplication   Size   Complexity  
A AclTest.php$0 ➔ __construct() 0 7 1
1
<?php
2
3
declare(strict_types=1);
4
5
namespace EcodevTests\Felix\Acl;
6
7
use Ecodev\Felix\Acl\Acl;
8
use Ecodev\Felix\Acl\Assertion\IsMyself;
9
use Ecodev\Felix\Acl\MultipleRoles;
10
use Ecodev\Felix\Model\CurrentUser;
11
use EcodevTests\Felix\Blog\Model\User;
12
use Laminas\Permissions\Acl\Assertion\AssertionInterface;
13
use Laminas\Permissions\Acl\Resource\ResourceInterface;
14
use Laminas\Permissions\Acl\Role\RoleInterface;
15
use PHPUnit\Framework\TestCase;
16
17
final class AclTest extends TestCase
18
{
19
    protected function tearDown(): void
20
    {
21
        CurrentUser::set(null);
22
    }
23
24
    public function testIsCurrentUserAllowed(): void
25
    {
26
        $acl = new class() extends Acl {
27
            public function __construct()
28
            {
29
                parent::__construct();
30
                $user = $this->createModelResource(User::class);
31
                $this->addRole('anonymous');
32
                $this->addRole('member');
33
                $this->allow('member', [$user], ['update'], new IsMyself());
34
            }
35
        };
36
37
        $user = new User();
38
39
        $owner = new User();
40
        $owner->setName('sarah');
41
        CurrentUser::set($owner);
42
        $user->setOwner($owner);
43
44
        CurrentUser::set(null);
45
        self::assertFalse($acl->isCurrentUserAllowed($user, 'update'), 'anonymous cannot update');
46
        self::assertSame('Non-logged user with role anonymous is not allowed on resource "User#null" with privilege "update"', $acl->getLastDenialMessage());
47
48
        CurrentUser::set($owner);
49
        self::assertFalse($acl->isCurrentUserAllowed($user, 'update'), 'student cannot update even if owner');
50
        self::assertSame('User "sarah" with role member is not allowed on resource "User#null" with privilege "update" because it is not himself', $acl->getLastDenialMessage());
51
52
        $other = new User();
53
        $other->setName('john');
54
        CurrentUser::set($other);
55
        self::assertFalse($acl->isCurrentUserAllowed($user, 'update'), 'other user cannot update');
56
        self::assertSame('User "john" with role member is not allowed on resource "User#null" with privilege "update" because it is not himself', $acl->getLastDenialMessage());
57
58
        // Test again the first case to assert that reject reason does not leak from one assertion to the next
59
        CurrentUser::set(null);
60
        self::assertFalse($acl->isCurrentUserAllowed($user, 'update'), 'anonymous cannot update');
61
        self::assertSame('Non-logged user with role anonymous is not allowed on resource "User#null" with privilege "update"', $acl->getLastDenialMessage());
62
    }
63
64
    public function testMultipleReasons(): void
65
    {
66
        $acl = new class() extends Acl {
67
            public function __construct()
68
            {
69
                parent::__construct();
70
                $user = $this->createModelResource(User::class);
71
                $this->addRole('anonymous');
72
                $this->addRole('member', 'anonymous');
73
                $this->allow(
74
                    'anonymous',
75
                    [$user],
76
                    ['update'],
77
                    new class() implements AssertionInterface {
78
                        /**
79
                         * @param Acl $acl
80
                         * @param null|mixed $privilege
81
                         */
82
                        public function assert(\Laminas\Permissions\Acl\Acl $acl, ?RoleInterface $role = null, ?ResourceInterface $resource = null, $privilege = null)
83
                        {
84
                            return $acl->reject('mocked reason');
0 ignored issues
show
Bug introduced by
The method reject() does not exist on Laminas\Permissions\Acl\Acl. It seems like you code against a sub-type of Laminas\Permissions\Acl\Acl such as Ecodev\Felix\Acl\Acl. ( Ignorable by Annotation )

If this is a false-positive, you can also ignore this issue in your code via the ignore-call  annotation

84
                            return $acl->/** @scrutinizer ignore-call */ reject('mocked reason');
Loading history...
85
                        }
86
                    }
87
                );
88
                $this->allow('member', [$user], ['update'], new IsMyself());
89
            }
90
        };
91
92
        $user = new User();
93
        $user->setName('sarah');
94
        CurrentUser::set($user);
95
96
        self::assertFalse($acl->isCurrentUserAllowed(new User(), 'update'), 'student cannot update even if user');
97
        $expected = <<<STRING
98
            User "sarah" with role member is not allowed on resource "User#null" with privilege "update" because:
99
100
            - it is not himself
101
            - mocked reason
102
            STRING;
103
        self::assertSame($expected, $acl->getLastDenialMessage());
104
    }
105
106
    public function testMultipleRoles(): void
107
    {
108
        $acl = new class() extends Acl {
109
            public function __construct()
110
            {
111
                parent::__construct();
112
                $user = $this->createModelResource(User::class);
113
                $this->addRole('reader');
114
                $this->addRole('writer');
115
                $this->allow('writer', [$user], ['update']);
116
            }
117
        };
118
119
        CurrentUser::set(new User(new MultipleRoles()));
120
        self::assertFalse($acl->isCurrentUserAllowed(new User(), 'update'));
121
        self::assertSame('User "" with role [] is not allowed on resource "User#null" with privilege "update"', $acl->getLastDenialMessage());
122
123
        CurrentUser::set(new User(new MultipleRoles(['reader'])));
124
        self::assertFalse($acl->isCurrentUserAllowed(new User(), 'update'));
125
        self::assertSame('User "" with role [reader] is not allowed on resource "User#null" with privilege "update"', $acl->getLastDenialMessage());
126
127
        CurrentUser::set(new User(new MultipleRoles(['reader', 'writer'])));
128
        self::assertTrue($acl->isCurrentUserAllowed(new User(), 'update'));
129
        self::assertNull($acl->getLastDenialMessage());
130
131
        self::assertFalse($acl->isAllowed(new MultipleRoles(), User::class, 'update'));
132
        self::assertFalse($acl->isAllowed(new MultipleRoles(['reader']), User::class, 'update'));
133
        self::assertTrue($acl->isAllowed(new MultipleRoles(['reader', 'writer']), User::class, 'update'));
134
    }
135
}
136