mirror of
https://github.com/InvoiceShelf/InvoiceShelf.git
synced 2026-04-15 17:24:10 +00:00
Complete rename across backend and frontend: - Controller: Company/Users/UsersController -> Company/Members/MembersController - Service: UserService -> MemberService - Requests: UserRequest -> MemberRequest, DeleteUserRequest -> DeleteMemberRequest - API routes: /api/v1/users -> /api/v1/members (company-scoped only) - Sidebar menu: "Users" -> "Members" - Frontend: views/users -> views/members, stores/users -> stores/members - Router: users.index -> members.index, /admin/users -> /admin/members - i18n: new "members" section with invitation-related keys - Tests: UserTest -> MemberTest Admin/super-admin Users (system-wide user management) remains unchanged.
48 lines
1023 B
PHP
48 lines
1023 B
PHP
<?php
|
|
|
|
use App\Models\User;
|
|
use Illuminate\Support\Facades\Artisan;
|
|
use Laravel\Sanctum\Sanctum;
|
|
|
|
use function Pest\Laravel\postJson;
|
|
|
|
beforeEach(function () {
|
|
Artisan::call('db:seed', ['--class' => 'DatabaseSeeder', '--force' => true]);
|
|
Artisan::call('db:seed', ['--class' => 'DemoSeeder', '--force' => true]);
|
|
|
|
$user = User::find(1);
|
|
$this->withHeaders([
|
|
'company' => $user->companies()->first()->id,
|
|
]);
|
|
Sanctum::actingAs(
|
|
$user,
|
|
['*']
|
|
);
|
|
});
|
|
|
|
test('create super admin role', function () {
|
|
$data = [
|
|
'email' => 'loremipsum@gmail.com',
|
|
'name' => 'lorem',
|
|
'password' => 'lorem@123',
|
|
];
|
|
$data['companies'] = [
|
|
[
|
|
'role' => 'super admin',
|
|
'id' => 1,
|
|
],
|
|
];
|
|
|
|
postJson('api/v1/members', $data)
|
|
->assertStatus(201);
|
|
|
|
$data = collect($data)
|
|
->only([
|
|
'email',
|
|
'name',
|
|
])
|
|
->toArray();
|
|
|
|
$this->assertDatabaseHas('users', $data);
|
|
});
|