mirror of
https://github.com/VueFileManager/vuefilemanager.git
synced 2026-04-05 18:23:48 +00:00
307 lines
8.7 KiB
PHP
307 lines
8.7 KiB
PHP
<?php
|
|
|
|
namespace Tests\Feature\Accounts;
|
|
|
|
use App\Models\User;
|
|
use App\Services\SetupService;
|
|
use Illuminate\Foundation\Testing\DatabaseMigrations;
|
|
use Illuminate\Foundation\Testing\RefreshDatabase;
|
|
use Illuminate\Auth\Notifications\VerifyEmail;
|
|
use Illuminate\Foundation\Testing\WithFaker;
|
|
use Illuminate\Http\UploadedFile;
|
|
use Laravel\Sanctum\Sanctum;
|
|
use Storage;
|
|
use Notification;
|
|
use Tests\TestCase;
|
|
use App\Models\Folder;
|
|
use Illuminate\Support\Facades\URL;
|
|
|
|
class UserAccountTest extends TestCase
|
|
{
|
|
use DatabaseMigrations;
|
|
|
|
public function __construct()
|
|
{
|
|
parent::__construct();
|
|
$this->setup = app()->make(SetupService::class);
|
|
}
|
|
|
|
/**
|
|
* @test
|
|
*/
|
|
public function it_change_user_password_in_profile_settings()
|
|
{
|
|
$user = User::factory(User::class)
|
|
->create();
|
|
|
|
Sanctum::actingAs($user);
|
|
|
|
$this->postJson('/api/user/password', [
|
|
'current_password' => 'secret',
|
|
'password' => 'VerySecretPassword',
|
|
'password_confirmation' => 'VerySecretPassword',
|
|
])->assertStatus(204);
|
|
|
|
// TODO: login s novym heslom
|
|
}
|
|
|
|
/**
|
|
* @test
|
|
*/
|
|
public function it_update_user_settings()
|
|
{
|
|
$user = User::factory(User::class)
|
|
->create();
|
|
|
|
Sanctum::actingAs($user);
|
|
|
|
$this->patchJson('/api/user/relationships/settings', [
|
|
'name' => 'address',
|
|
'value' => 'Jantar',
|
|
])->assertStatus(204);
|
|
|
|
$this->assertDatabaseHas('user_settings', [
|
|
'address' => 'Jantar',
|
|
]);
|
|
}
|
|
|
|
/**
|
|
* @test
|
|
*/
|
|
public function it_update_user_avatar()
|
|
{
|
|
Storage::fake('local');
|
|
|
|
$this->setup->create_directories();
|
|
|
|
$user = User::factory(User::class)
|
|
->create();
|
|
|
|
Sanctum::actingAs($user);
|
|
|
|
$avatar = UploadedFile::fake()
|
|
->image('fake-image.jpg');
|
|
|
|
$this->patchJson('/api/user/relationships/settings', [
|
|
'avatar' => $avatar,
|
|
])->assertStatus(204);
|
|
|
|
Storage::disk('local')
|
|
->assertExists($user->settings->getRawOriginal('avatar'));
|
|
}
|
|
|
|
/**
|
|
* @test
|
|
*/
|
|
public function it_get_user_data()
|
|
{
|
|
$user = User::factory(User::class)
|
|
->create();
|
|
|
|
Sanctum::actingAs($user);
|
|
|
|
$this->getJson('/api/user')
|
|
->assertStatus(200)
|
|
->assertExactJson([
|
|
"data" => [
|
|
"id" => (string)$user->id,
|
|
"type" => "user",
|
|
"attributes" => [
|
|
"storage_capacity" => "5",
|
|
"subscription" => false,
|
|
"incomplete_payment" => null,
|
|
"stripe_customer" => false,
|
|
"email" => $user->email,
|
|
"role" => $user->role,
|
|
"folders" => [],
|
|
"storage" => [
|
|
"used" => 0,
|
|
"used_formatted" => "0.00%",
|
|
"capacity" => "5",
|
|
"capacity_formatted" => "5GB",
|
|
],
|
|
"created_at_formatted" => format_date($user->created_at, '%d. %B. %Y'),
|
|
"created_at" => $user->created_at->toJson(),
|
|
"updated_at" => $user->updated_at->toJson(),
|
|
],
|
|
"relationships" => [
|
|
"settings" => [
|
|
"data" => [
|
|
"id" => (string)$user->id,
|
|
"type" => "settings",
|
|
"attributes" => [
|
|
'avatar' => $user->settings->avatar,
|
|
'name' => $user->settings->name,
|
|
'address' => $user->settings->address,
|
|
'state' => $user->settings->state,
|
|
'city' => $user->settings->city,
|
|
'postal_code' => $user->settings->postal_code,
|
|
'country' => $user->settings->country,
|
|
'phone_number' => $user->settings->phone_number,
|
|
'timezone' => $user->settings->timezone
|
|
]
|
|
]
|
|
],
|
|
"favourites" => [
|
|
"data" => [
|
|
"id" => (string)$user->id,
|
|
"type" => "favourite_folders",
|
|
"attributes" => [
|
|
"folders" => []
|
|
]
|
|
]
|
|
],
|
|
]
|
|
],
|
|
]);
|
|
}
|
|
|
|
/**
|
|
* @test
|
|
*/
|
|
public function it_create_user_token()
|
|
{
|
|
$user = User::factory(User::class)
|
|
->create();
|
|
|
|
Sanctum::actingAs($user);
|
|
|
|
$this->postJson('/api/user/token/create')
|
|
->assertStatus(201);
|
|
|
|
$this->assertDatabaseHas('personal_access_tokens', [
|
|
'tokenable_id' => $user->id,
|
|
]);
|
|
}
|
|
|
|
/**
|
|
* @test
|
|
*/
|
|
public function it_revoke_user_token()
|
|
{
|
|
$user = User::factory(User::class)
|
|
->create();
|
|
|
|
Sanctum::actingAs($user);
|
|
|
|
$user->createToken('token');
|
|
|
|
$token_id = $user->tokens()->first()->id;
|
|
|
|
$this->deleteJson("/api/user/token/revoke/$token_id")
|
|
->assertStatus(204);
|
|
|
|
$this->assertDatabaseMissing('personal_access_tokens', [
|
|
'id' => $token_id
|
|
]);
|
|
}
|
|
|
|
/**
|
|
* @test
|
|
*/
|
|
public function it_get_user_tokens()
|
|
{
|
|
$user = User::factory(User::class)
|
|
->create();
|
|
|
|
Sanctum::actingAs($user);
|
|
|
|
$user->createToken('token');
|
|
|
|
$token = $user->tokens()->first();
|
|
|
|
$this->getJson('/api/user/tokens')
|
|
->assertStatus(200)
|
|
->assertJsonFragment([
|
|
"id" => $token->id,
|
|
"tokenable_type" => $token->tokenable_type,
|
|
"tokenable_id" => $user->id,
|
|
"name" => $token->name,
|
|
"abilities" => $token->abilities
|
|
]);
|
|
}
|
|
|
|
/**
|
|
* @test
|
|
*/
|
|
public function it_use_user_token_to_request()
|
|
{
|
|
$user = User::factory(User::class)
|
|
->create();
|
|
|
|
$folder = Folder::factory(Folder::class)
|
|
->create([
|
|
'user_id' => $user->id,
|
|
]);
|
|
|
|
$token = $user->createToken('token')->plainTextToken;
|
|
|
|
$this->assertDatabaseHas('personal_access_tokens', [
|
|
'tokenable_id' => $user->id
|
|
]);
|
|
|
|
$this->assertDatabaseHas('folders', [
|
|
'id' => $folder->id,
|
|
'user_id' => $user->id
|
|
]);
|
|
|
|
$response = $this->call('GET', "api/browse/folders/$folder->id",
|
|
[], [], [], [
|
|
'Content-type' => 'application/json',
|
|
'Accept' => 'application/json',
|
|
'Authorization' => 'Bearer ' .$token,
|
|
]);
|
|
|
|
|
|
// $response->assertJsonFragment([
|
|
// 'id' => $folder->id,
|
|
// 'user_id' => $user->id,
|
|
// ]);
|
|
|
|
// dd($response);
|
|
}
|
|
|
|
/**
|
|
* @test
|
|
*/
|
|
public function it_user_email_verify()
|
|
{
|
|
$user = User::factory(User::class)
|
|
->create([
|
|
'email_verified_at' => null
|
|
]);
|
|
|
|
$verificationUrl = URL::temporarySignedRoute(
|
|
'verification.verify',
|
|
now()->addMinutes(60),
|
|
['id' => $user->id, 'hash' => sha1($user->email)]
|
|
);
|
|
|
|
$response = $this->getJson($verificationUrl);
|
|
|
|
$response->assertRedirect('successfully-verified');
|
|
|
|
$this->assertNotNull(User::find($user->id)->get('email_verified_at'));
|
|
}
|
|
|
|
/**
|
|
* @test
|
|
*/
|
|
public function it_resend_user_verify_email()
|
|
{
|
|
Notification::fake();
|
|
|
|
$user = User::factory(User::class)
|
|
->create([
|
|
'email_verified_at' => null
|
|
]);
|
|
|
|
$this->postJson('/api/user/email/resend/verify', [
|
|
'email' => $user->email,
|
|
])
|
|
->assertStatus(200);
|
|
|
|
Notification::assertTimesSent(1, VerifyEmail::class);
|
|
}
|
|
}
|