forked from ProcessMaker/processmaker
-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathUserTest.php
More file actions
89 lines (69 loc) · 3.1 KB
/
UserTest.php
File metadata and controls
89 lines (69 loc) · 3.1 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
<?php
namespace Tests\Model;
use Illuminate\Support\Facades\Hash;
use Tests\TestCase;
use ProcessMaker\Models\User;
use ProcessMaker\Models\Group;
use ProcessMaker\Models\Permission;
use ProcessMaker\Models\GroupMember;
use ProcessMaker\Models\PermissionAssignment;
use ProcessMaker\Providers\AuthServiceProvider;
class UserTest extends TestCase
{
public function testPermissions() {
$president_user = factory(User::class)->create(['password' => Hash::make('password')]);
$technician_user = factory(User::class)->create(['password' => Hash::make('password')]);
$mom_user = factory(User::class)->create(['password' => Hash::make('password')]);
$ln_permission = factory(Permission::class)->create([
'name' => 'launch.nukes',
]);
$dn_permission = factory(Permission::class)->create([
'name' => 'disarm.nukes',
]);
$nl_group = factory(Group::class)->create(['name' => 'Nuke Launchers']);
$p_group = factory(Group::class)->create(['name' => 'Presidents']);
// TODO: Make this work with attach
// factory(GroupMember::class)->create([
// 'group_id' => $nl_group->id,
// 'member_type' => Group::class,
// 'member_id' => $p_group,
// ]);
// $nl_group->childGroups()->attach($p_group);
factory(GroupMember::class)->create([
'group_id' => $nl_group->id,
'member_type' => User::class,
'member_id' => $technician_user,
]);
factory(GroupMember::class)->create([
'group_id' => $p_group->id,
'member_type' => User::class,
'member_id' => $president_user->id,
]);
$p_group->permissions()->attach($ln_permission);
$nl_group->permissions()->attach($dn_permission);
$mom_user->permissions()->attach($dn_permission);
$this->assertTrue($president_user->hasPermission('launch.nukes'));
// TODO: Groups belong to groups
// $this->assertTrue($president_user->hasPermission('disarm.nukes'));
$this->assertFalse($technician_user->hasPermission('launch.nukes'));
$this->assertTrue($technician_user->hasPermission('disarm.nukes'));
$this->assertTrue($mom_user->hasPermission('disarm.nukes'));
$this->assertFalse($mom_user->hasPermission('launch.nukes'));
}
public function testCanAny()
{
$user = factory(User::class)->create();
$p1 = factory(Permission::class)->create(['name' => 'foo']);
$p2 = factory(Permission::class)->create(['name' => 'bar']);
$p3 = factory(Permission::class)->create(['name' => 'baz']);
(new AuthServiceProvider(app()))->boot();
$this->assertFalse($user->can('bar'));
$this->assertFalse($user->canAny('foo|bar'));
$user->permissions()->attach($p2);
$user->permissions()->attach($p3);
$user->refresh();
$this->assertTrue($user->can('bar'));
$this->assertEquals('bar', $user->canAny('foo|bar'));
$this->assertEquals('baz', $user->canAny('foo|baz'));
}
}