mirror of
https://github.com/VueFileManager/vuefilemanager.git
synced 2026-04-18 16:22:14 +00:00
added it_get_all_users, it_get_single_user, it_get_user_storage_detail test
This commit is contained in:
@@ -2,8 +2,8 @@
|
|||||||
|
|
||||||
namespace App\Http\Controllers\Admin;
|
namespace App\Http\Controllers\Admin;
|
||||||
|
|
||||||
use App\File;
|
use App\Models\File;
|
||||||
use App\Folder;
|
use App\Models\Folder;
|
||||||
use App\Http\Controllers\Controller;
|
use App\Http\Controllers\Controller;
|
||||||
use App\Http\Requests\Admin\ChangeRoleRequest;
|
use App\Http\Requests\Admin\ChangeRoleRequest;
|
||||||
use App\Http\Requests\Admin\ChangeStorageCapacityRequest;
|
use App\Http\Requests\Admin\ChangeStorageCapacityRequest;
|
||||||
@@ -14,18 +14,14 @@ use App\Http\Resources\UsersCollection;
|
|||||||
use App\Http\Resources\UserResource;
|
use App\Http\Resources\UserResource;
|
||||||
use App\Http\Resources\UserStorageResource;
|
use App\Http\Resources\UserStorageResource;
|
||||||
use App\Http\Resources\UserSubscription;
|
use App\Http\Resources\UserSubscription;
|
||||||
use App\Http\Tools\Demo;
|
|
||||||
use App\Services\StripeService;
|
use App\Services\StripeService;
|
||||||
use App\Share;
|
use App\Models\Share;
|
||||||
use App\User;
|
use App\Models\User;
|
||||||
use App\UserSettings;
|
use App\Models\UserSettings;
|
||||||
use Illuminate\Contracts\Routing\ResponseFactory;
|
use Illuminate\Contracts\Routing\ResponseFactory;
|
||||||
use Illuminate\Http\Request;
|
|
||||||
use Illuminate\Support\Facades\Auth;
|
use Illuminate\Support\Facades\Auth;
|
||||||
use Illuminate\Support\Facades\Gate;
|
|
||||||
use Illuminate\Support\Facades\Hash;
|
use Illuminate\Support\Facades\Hash;
|
||||||
use Illuminate\Support\Facades\Password;
|
use Illuminate\Support\Facades\Password;
|
||||||
use Illuminate\Support\Str;
|
|
||||||
use Storage;
|
use Storage;
|
||||||
|
|
||||||
class UserController extends Controller
|
class UserController extends Controller
|
||||||
@@ -68,10 +64,10 @@ class UserController extends Controller
|
|||||||
*/
|
*/
|
||||||
public function invoices($id)
|
public function invoices($id)
|
||||||
{
|
{
|
||||||
$user = User::find($id);
|
|
||||||
|
|
||||||
return new InvoiceCollection(
|
return new InvoiceCollection(
|
||||||
$this->stripe->getUserInvoices($user)
|
$this->stripe->getUserInvoices(
|
||||||
|
User::find($id)
|
||||||
|
)
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -102,7 +98,8 @@ class UserController extends Controller
|
|||||||
public function users()
|
public function users()
|
||||||
{
|
{
|
||||||
return new UsersCollection(
|
return new UsersCollection(
|
||||||
User::sortable(['created_at', 'DESC'])->paginate('20')
|
User::sortable(['created_at', 'DESC'])
|
||||||
|
->paginate(20)
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
@@ -2,7 +2,7 @@
|
|||||||
|
|
||||||
namespace App\Http\Resources;
|
namespace App\Http\Resources;
|
||||||
|
|
||||||
use App\File;
|
use App\Models\File;
|
||||||
use ByteUnits\Metric;
|
use ByteUnits\Metric;
|
||||||
use Illuminate\Http\Resources\Json\JsonResource;
|
use Illuminate\Http\Resources\Json\JsonResource;
|
||||||
|
|
||||||
|
|||||||
@@ -47,10 +47,10 @@ class AdminTest extends TestCase
|
|||||||
$this->getJson('/api/admin/dashboard')
|
$this->getJson('/api/admin/dashboard')
|
||||||
->assertStatus(200)
|
->assertStatus(200)
|
||||||
->assertExactJson([
|
->assertExactJson([
|
||||||
"license" => "Regular",
|
"license" => 'Regular',
|
||||||
"app_version" => config('vuefilemanager.version'),
|
"app_version" => config('vuefilemanager.version'),
|
||||||
"total_users" => 1,
|
"total_users" => 1,
|
||||||
"total_used_space" => "2.00MB",
|
"total_used_space" => '2.00MB',
|
||||||
"total_premium_users" => 1,
|
"total_premium_users" => 1,
|
||||||
]);
|
]);
|
||||||
}
|
}
|
||||||
@@ -77,4 +77,109 @@ class AdminTest extends TestCase
|
|||||||
]);
|
]);
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @test
|
||||||
|
*/
|
||||||
|
public function it_get_all_users()
|
||||||
|
{
|
||||||
|
$users = User::factory(User::class)
|
||||||
|
->count(5)
|
||||||
|
->create(['role' => 'user']);
|
||||||
|
|
||||||
|
$admin = User::factory(User::class)
|
||||||
|
->create(['role' => 'admin']);
|
||||||
|
|
||||||
|
Sanctum::actingAs($admin);
|
||||||
|
|
||||||
|
$users->each(function ($user) {
|
||||||
|
$this->getJson('/api/admin/users?page=1')
|
||||||
|
->assertStatus(200)
|
||||||
|
->assertJsonFragment([
|
||||||
|
'id' => $user->id,
|
||||||
|
]);
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @test
|
||||||
|
*/
|
||||||
|
public function it_get_single_user()
|
||||||
|
{
|
||||||
|
$user = User::factory(User::class)
|
||||||
|
->create(['role' => 'user']);
|
||||||
|
|
||||||
|
$admin = User::factory(User::class)
|
||||||
|
->create(['role' => 'admin']);
|
||||||
|
|
||||||
|
Sanctum::actingAs($admin);
|
||||||
|
|
||||||
|
// TODO: pridat exactjson po refaktorovani userresource
|
||||||
|
$this->getJson("/api/admin/users/$user->id/detail")
|
||||||
|
->assertStatus(200)
|
||||||
|
->assertJsonFragment([
|
||||||
|
'id' => $user->id,
|
||||||
|
]);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @test
|
||||||
|
*/
|
||||||
|
public function it_get_user_storage_detail()
|
||||||
|
{
|
||||||
|
$user = User::factory(User::class)
|
||||||
|
->create(['role' => 'user']);
|
||||||
|
|
||||||
|
collect(['image', 'audio', 'video', 'pdf', 'zip'])
|
||||||
|
->each(function ($mimetype) use ($user) {
|
||||||
|
File::factory(File::class)
|
||||||
|
->create([
|
||||||
|
'user_id' => $user->id,
|
||||||
|
'type' => $mimetype,
|
||||||
|
'mimetype' => $mimetype,
|
||||||
|
'filesize' => 1000000,
|
||||||
|
]);
|
||||||
|
});
|
||||||
|
|
||||||
|
$admin = User::factory(User::class)
|
||||||
|
->create(['role' => 'admin']);
|
||||||
|
|
||||||
|
Sanctum::actingAs($admin);
|
||||||
|
|
||||||
|
$this->getJson("/api/admin/users/$user->id/storage")
|
||||||
|
->assertStatus(200)
|
||||||
|
->assertExactJson([
|
||||||
|
"data" => [
|
||||||
|
"id" => $user->id,
|
||||||
|
"type" => "storage",
|
||||||
|
"attributes" => [
|
||||||
|
"used" => "5.00MB",
|
||||||
|
"capacity" => "5GB",
|
||||||
|
"percentage" => 0.1,
|
||||||
|
],
|
||||||
|
"meta" => [
|
||||||
|
"images" => [
|
||||||
|
"used" => '1.00MB',
|
||||||
|
"percentage" => 0.02,
|
||||||
|
],
|
||||||
|
"audios" => [
|
||||||
|
"used" => '1.00MB',
|
||||||
|
"percentage" => 0.02,
|
||||||
|
],
|
||||||
|
"videos" => [
|
||||||
|
"used" => '1.00MB',
|
||||||
|
"percentage" => 0.02,
|
||||||
|
],
|
||||||
|
"documents" => [
|
||||||
|
"used" => '1.00MB',
|
||||||
|
"percentage" => 0.02,
|
||||||
|
],
|
||||||
|
"others" => [
|
||||||
|
"used" => '1.00MB',
|
||||||
|
"percentage" => 0.02,
|
||||||
|
]
|
||||||
|
]
|
||||||
|
]
|
||||||
|
]);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
Reference in New Issue
Block a user