forked from laravel/jetstream
-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathTeamMemberControllerTest.php
100 lines (74 loc) · 2.59 KB
/
TeamMemberControllerTest.php
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
90
91
92
93
94
95
96
97
98
99
100
<?php
namespace Laravel\Jetstream\Tests;
use App\Actions\Jetstream\CreateTeam;
use App\Models\Team;
use Illuminate\Support\Facades\Gate;
use Laravel\Jetstream\Jetstream;
use Laravel\Jetstream\Tests\Fixtures\TeamPolicy;
use Laravel\Jetstream\Tests\Fixtures\User;
use Laravel\Sanctum\TransientToken;
class TeamMemberControllerTest extends OrchestraTestCase
{
public function setUp(): void
{
parent::setUp();
Gate::policy(Team::class, TeamPolicy::class);
Jetstream::useUserModel(User::class);
}
public function test_team_member_permissions_can_be_updated()
{
Jetstream::role('admin', 'Admin', ['foo', 'bar']);
Jetstream::role('editor', 'Editor', ['baz', 'qux']);
$this->migrate();
$team = $this->createTeam();
$adam = User::forceCreate([
'name' => 'Adam Wathan',
'email' => 'adam@laravel.com',
'password' => 'secret',
]);
$team->users()->attach($adam, ['role' => 'admin']);
$response = $this->actingAs($team->owner)->put('/teams/'.$team->id.'/members/'.$adam->id, [
'role' => 'editor',
]);
$response->assertRedirect();
$adam = $adam->fresh();
$adam->withAccessToken(new TransientToken);
$this->assertTrue($adam->hasTeamPermission($team, 'baz'));
$this->assertTrue($adam->hasTeamPermission($team, 'qux'));
}
public function test_team_member_permissions_cant_be_updated_if_not_authorized()
{
$this->migrate();
$team = $this->createTeam();
$adam = User::forceCreate([
'name' => 'Adam Wathan',
'email' => 'adam@laravel.com',
'password' => 'secret',
]);
$team->users()->attach($adam, ['role' => 'admin']);
$response = $this->actingAs($adam)->put('/teams/'.$team->id.'/members/'.$adam->id, [
'role' => 'admin',
]);
$response->assertStatus(403);
}
protected function createTeam()
{
$action = new CreateTeam;
$user = User::forceCreate([
'name' => 'Taylor Otwell',
'email' => 'taylor@laravel.com',
'password' => 'secret',
]);
return $action->create($user, ['name' => 'Test Team']);
}
protected function migrate()
{
$this->artisan('migrate', ['--database' => 'testbench'])->run();
}
protected function getEnvironmentSetUp($app)
{
parent::getEnvironmentSetUp($app);
$app['config']->set('jetstream.stack', 'inertia');
$app['config']->set('jetstream.features', ['teams']);
}
}