added it_create_new_user_with_avatar test

This commit is contained in:
Peter Papp
2021-03-04 17:47:26 +01:00
parent 2782dc879b
commit 5844e66b7f
2 changed files with 57 additions and 23 deletions
+18 -22
View File
@@ -82,7 +82,7 @@ class UserController extends Controller
*/ */
public function subscription(User $user) public function subscription(User $user)
{ {
if (! $user->stripeId() || ! $user->subscription('main')) { if (!$user->stripeId() || !$user->subscription('main')) {
return response("User doesn't have any subscription.", 404); return response("User doesn't have any subscription.", 404);
} }
@@ -174,57 +174,53 @@ class UserController extends Controller
* Create new user by admin * Create new user by admin
* *
* @param CreateUserByAdmin $request * @param CreateUserByAdmin $request
* @return UserResource * @return UserResource|Application|ResponseFactory|Response
*/ */
public function create_user(CreateUserByAdmin $request) public function create_user(CreateUserByAdmin $request)
{ {
// Store avatar // Store avatar
if ($request->hasFile('avatar')) { if ($request->hasFile('avatar')) {
$avatar = store_avatar($request->file('avatar'), 'avatars'); $avatar = store_avatar($request->file('avatar'));
} }
// Create user // Create user
$user = User::forceCreate([ $user = User::forceCreate([
'avatar' => $request->hasFile('avatar') ? $avatar : null,
'name' => $request->name,
'role' => $request->role, 'role' => $request->role,
'email' => $request->email, 'email' => $request->email,
'password' => Hash::make($request->password), 'password' => Hash::make($request->password),
]); ]);
// Create settings // Create settings
UserSettings::forceCreate([ $user
'user_id' => $user->id, ->settings()
'storage_capacity' => $request->storage_capacity, ->create([
]); 'name' => $request->name,
'avatar' => $avatar ?? null,
'storage_capacity' => $request->storage_capacity,
]);
return new UserResource($user); return response(new UserResource($user), 201);
} }
/** /**
* Delete user with all user data * Delete user with all user data
* *
* @param DeleteUserRequest $request * @param DeleteUserRequest $request
* @param $id * @param User $user
* @return ResponseFactory|Response * @return ResponseFactory|Response
* @throws \Exception
*/ */
public function delete_user(DeleteUserRequest $request, $id) public function delete_user(DeleteUserRequest $request, User $user)
{ {
$user = User::findOrFail($id);
if ($user->subscribed('main')) {
abort(202, 'You can\'t delete this account while user have active subscription.');
}
// Demo preview
if (env('APP_DEMO')) { if (env('APP_DEMO')) {
return response('Done!', 204); return response('Done!', 204);
} }
// Check for self deleted account if ($user->subscribed('main')) {
abort(202, "You can\'t delete this account while user have active subscription.");
}
if ($user->id === Auth::id()) { if ($user->id === Auth::id()) {
abort(406, 'You can\'t delete your account'); abort(406, "You can\'t delete your account");
} }
// Validate user name // Validate user name
+39 -1
View File
@@ -8,8 +8,10 @@ use App\Models\User;
use App\Notifications\ResetPassword; use App\Notifications\ResetPassword;
use DB; use DB;
use Illuminate\Foundation\Testing\DatabaseMigrations; use Illuminate\Foundation\Testing\DatabaseMigrations;
use Illuminate\Http\UploadedFile;
use Notification; use Notification;
use Laravel\Sanctum\Sanctum; use Laravel\Sanctum\Sanctum;
use Storage;
use Tests\TestCase; use Tests\TestCase;
class AdminTest extends TestCase class AdminTest extends TestCase
@@ -121,7 +123,6 @@ class AdminTest extends TestCase
]); ]);
} }
/** /**
* @test * @test
*/ */
@@ -267,4 +268,41 @@ class AdminTest extends TestCase
$this->assertTrue(User::find($user->id)->role === 'admin'); $this->assertTrue(User::find($user->id)->role === 'admin');
} }
/**
* @test
*/
public function it_create_new_user_with_avatar()
{
Storage::fake('local');
$admin = User::factory(User::class)
->create(['role' => 'admin']);
Sanctum::actingAs($admin);
$avatar = UploadedFile::fake()
->image('fake-image.jpg');
$this->postJson("/api/admin/users/create", [
'name' => 'John Doe',
'role' => 'user',
'email' => 'john@doe.com',
'password' => 'VerySecretPassword',
'storage_capacity' => 15,
'password_confirmation' => 'VerySecretPassword',
'avatar' => $avatar,
])->assertStatus(201);
$this->assertDatabaseHas('users', [
'email' => 'john@doe.com'
]);
$this->assertDatabaseHas('user_settings', [
'name' => 'John Doe'
]);
Storage::disk('local')
->assertExists(User::whereEmail('john@doe.com')->first()->settings->getRawOriginal('avatar'));
}
} }