mirror of
https://github.com/InvoiceShelf/InvoiceShelf.git
synced 2026-04-15 17:24:10 +00:00
V1/Admin -> Company (company-scoped controllers) V1/SuperAdmin -> Admin (platform-wide admin controllers) V1/Customer -> CustomerPortal (customer-facing portal) V1/Installation -> Setup (installation wizard) V1/PDF -> Pdf (consistent casing) V1/Modules -> Modules (drop V1 prefix) V1/Webhook -> Webhook (drop V1 prefix) The V1 prefix served no purpose - API versioning is in the route prefix (/api/v1/), not the controller namespace. "Admin" was misleading for company-scoped controllers. "SuperAdmin" is now simply "Admin" for platform administration.
98 lines
2.4 KiB
PHP
98 lines
2.4 KiB
PHP
<?php
|
|
|
|
use App\Http\Controllers\Company\Users\UsersController;
|
|
use App\Http\Requests\UserRequest;
|
|
use App\Models\User;
|
|
use Laravel\Sanctum\Sanctum;
|
|
|
|
use function Pest\Faker\fake;
|
|
use function Pest\Laravel\getJson;
|
|
use function Pest\Laravel\postJson;
|
|
use function Pest\Laravel\putJson;
|
|
|
|
beforeEach(function () {
|
|
Artisan::call('db:seed', ['--class' => 'DatabaseSeeder', '--force' => true]);
|
|
Artisan::call('db:seed', ['--class' => 'DemoSeeder', '--force' => true]);
|
|
|
|
$user = User::where('role', 'super admin')->first();
|
|
|
|
$this->withHeaders([
|
|
'company' => $user->companies()->first()->id,
|
|
]);
|
|
|
|
Sanctum::actingAs(
|
|
$user,
|
|
['*']
|
|
);
|
|
});
|
|
|
|
getJson('/api/v1/users')->assertOk();
|
|
|
|
test('store user using a form request', function () {
|
|
$this->assertActionUsesFormRequest(
|
|
UsersController::class,
|
|
'store',
|
|
UserRequest::class
|
|
);
|
|
});
|
|
|
|
// test('store user', function () {
|
|
// $data = [
|
|
// 'name' => fake()->name,
|
|
// 'email' => fake()->unique()->safeEmail,
|
|
// 'phone' => fake()->phoneNumber,
|
|
// 'password' => fake()->password
|
|
// ];
|
|
|
|
// postJson('/api/v1/users', $data)->assertOk();
|
|
|
|
// $this->assertDatabaseHas('users', [
|
|
// 'name' => $data['name'],
|
|
// 'email' => $data['email'],
|
|
// 'phone' => $data['phone'],
|
|
// ]);
|
|
// });
|
|
|
|
test('get user', function () {
|
|
$user = User::factory()->create();
|
|
|
|
getJson("/api/v1/users/{$user->id}")->assertOk();
|
|
});
|
|
|
|
test('update user using a form request', function () {
|
|
$this->assertActionUsesFormRequest(
|
|
UsersController::class,
|
|
'update',
|
|
UserRequest::class
|
|
);
|
|
});
|
|
|
|
// test('update user', function () {
|
|
// $user = User::factory()->create();
|
|
|
|
// $data = [
|
|
// 'name' => fake()->name,
|
|
// 'email' => fake()->unique()->safeEmail,
|
|
// 'phone' => fake()->phoneNumber,
|
|
// 'password' => fake()->password
|
|
// ];
|
|
|
|
// putJson("/api/v1/users/{$user->id}", $data)->assertOk();
|
|
|
|
// $this->assertDatabaseHas('users', [
|
|
// 'name' => $data['name'],
|
|
// 'email' => $data['email'],
|
|
// 'phone' => $data['phone'],
|
|
// ]);
|
|
// });
|
|
|
|
// test('delete users', function () {
|
|
// $user = User::factory()->create();
|
|
// $data['users'] = [$user->id];
|
|
|
|
// postJson("/api/v1/users/delete", $data)
|
|
// ->assertOk();
|
|
|
|
// $this->assertModelMissing($user);
|
|
// });
|