test groups refactoring

This commit is contained in:
Peter Papp
2021-07-18 16:53:12 +02:00
parent 18150cd920
commit a1778eab52
83 changed files with 1482 additions and 1421 deletions

View File

@@ -1,12 +1,12 @@
<?php
namespace Tests\Feature\FileManager;
namespace Tests\Domain\Files;
use App\Models\File;
use App\Models\Folder;
use App\Models\User;
use App\Models\Zip;
use App\Services\SetupService;
use Domain\Settings\Models\File;
use Domain\Settings\Models\Folder;
use Domain\Settings\Models\User;
use Domain\Settings\Models\Zip;
use Domain\SetupWizard\Services\SetupService;
use Illuminate\Http\UploadedFile;
use Illuminate\Support\Str;
use Laravel\Sanctum\Sanctum;
@@ -26,8 +26,6 @@ class ContentAccessTest extends TestCase
*/
public function it_get_public_user_avatar()
{
$this->setup->create_directories();
$avatar = UploadedFile::fake()
->image('fake-avatar.jpg');
@@ -44,8 +42,6 @@ class ContentAccessTest extends TestCase
*/
public function it_get_public_system_image()
{
$this->setup->create_directories();
$system = UploadedFile::fake()
->image('fake-logo.jpg');
@@ -62,8 +58,6 @@ class ContentAccessTest extends TestCase
*/
public function it_get_private_user_file()
{
$this->setup->create_directories();
$user = User::factory(User::class)
->create();
@@ -79,9 +73,9 @@ class ContentAccessTest extends TestCase
'name' => 'fake-file.pdf',
]);
Sanctum::actingAs($user);
$this->get("file/$file->name")
$this
->actingAs($user)
->get("file/$file->name")
->assertOk();
}
@@ -90,8 +84,6 @@ class ContentAccessTest extends TestCase
*/
public function it_get_private_user_image_thumbnail()
{
$this->setup->create_directories();
$user = User::factory(User::class)
->create();
@@ -107,9 +99,9 @@ class ContentAccessTest extends TestCase
'name' => 'fake-thumbnail.jpg',
]);
Sanctum::actingAs($user);
$this->get("thumbnail/$thumbnail->name")
$this
->actingAs($user)
->get("thumbnail/$thumbnail->name")
->assertStatus(200);
}
@@ -118,13 +110,9 @@ class ContentAccessTest extends TestCase
*/
public function it_get_private_user_zip()
{
$this->setup->create_directories();
$user = User::factory(User::class)
->create();
Sanctum::actingAs($user);
$file = UploadedFile::fake()
->create('archive.zip', 2000, 'application/zip');
@@ -135,7 +123,9 @@ class ContentAccessTest extends TestCase
'user_id' => $user->id,
]);
$this->get("zip/$zip->id")
$this
->actingAs($user)
->get("zip/$zip->id")
->assertOk();
}
@@ -144,8 +134,6 @@ class ContentAccessTest extends TestCase
*/
public function logged_user_try_to_get_another_private_user_image_thumbnail()
{
$this->setup->create_directories();
$users = User::factory(User::class)
->count(2)
->create();
@@ -173,8 +161,6 @@ class ContentAccessTest extends TestCase
*/
public function logged_user_try_to_get_another_private_user_file()
{
$this->setup->create_directories();
$users = User::factory(User::class)
->count(2)
->create();
@@ -202,13 +188,9 @@ class ContentAccessTest extends TestCase
*/
public function logged_user_try_to_get_another_private_user_zip()
{
$this->setup->create_directories();
$user = User::factory(User::class)
->create();
Sanctum::actingAs($user);
$file = UploadedFile::fake()
->create('archive.zip', 2000, 'application/zip');
@@ -218,7 +200,9 @@ class ContentAccessTest extends TestCase
'basename' => 'EHWKcuvKzA4Gv29v-archive.zip',
]);
$this->get("zip/$zip->id")
$this
->actingAs($user)
->get("zip/$zip->id")
->assertNotFound();
}

View File

@@ -1,13 +1,12 @@
<?php
namespace Tests\Feature\FileManager;
namespace Tests\Domain\Files;
use App\Models\File;
use App\Models\Folder;
use App\Models\Setting;
use App\Models\User;
use App\Models\Zip;
use App\Services\SetupService;
use Domain\Settings\Models\File;
use Domain\Settings\Models\Folder;
use Domain\Settings\Models\Setting;
use Domain\Settings\Models\User;
use Domain\SetupWizard\Services\SetupService;
use Illuminate\Http\UploadedFile;
use Laravel\Sanctum\Sanctum;
use Storage;
@@ -39,17 +38,15 @@ class FileTest extends TestCase
*/
public function it_upload_image_file_and_create_thumbnail()
{
$this->setup->create_directories();
$file = UploadedFile::fake()
->image('fake-image.jpg');
$user = User::factory(User::class)
->create();
Sanctum::actingAs($user);
$this->postJson('/api/upload', [
$this
->actingAs($user)
->postJson('/api/upload', [
'filename' => $file->name,
'file' => $file,
'folder_id' => null,
@@ -80,17 +77,15 @@ class FileTest extends TestCase
*/
public function it_upload_new_file()
{
$this->setup->create_directories();
$file = UploadedFile::fake()
->create('fake-file.pdf', 1200, 'application/pdf');
$user = User::factory(User::class)
->create();
Sanctum::actingAs($user);
$this->postJson('/api/upload', [
$this
->actingAs($user)
->postJson('/api/upload', [
'filename' => $file->name,
'file' => $file,
'folder_id' => null,
@@ -117,8 +112,6 @@ class FileTest extends TestCase
*/
public function it_upload_blacklisted_mimetype_file()
{
$this->setup->create_directories();
Setting::create([
'name' => 'mimetypes_blacklist',
'value' => 'pdf',
@@ -130,9 +123,9 @@ class FileTest extends TestCase
$user = User::factory(User::class)
->create();
Sanctum::actingAs($user);
$this->postJson('/api/upload', [
$this
->actingAs($user)
->postJson('/api/upload', [
'file' => $file,
'folder_id' => null,
'is_last' => true,
@@ -153,9 +146,9 @@ class FileTest extends TestCase
$user = User::factory(User::class)
->create();
Sanctum::actingAs($user);
$this->patchJson("/api/rename/{$file->id}", [
$this
->actingAs($user)
->patchJson("/api/rename/{$file->id}", [
'name' => 'Renamed Item',
'type' => 'file',
])
@@ -183,9 +176,9 @@ class FileTest extends TestCase
$user = User::factory(User::class)
->create();
Sanctum::actingAs($user);
$this->postJson("/api/move", [
$this
->actingAs($user)
->postJson("/api/move", [
'to_id' => $folder->id,
'items' => [
[
@@ -213,9 +206,9 @@ class FileTest extends TestCase
->count(2)
->create();
Sanctum::actingAs($user);
$this->postJson("/api/remove", [
$this
->actingAs($user)
->postJson("/api/remove", [
'items' => [
[
'id' => $files[0]->id,
@@ -243,8 +236,6 @@ class FileTest extends TestCase
*/
public function it_delete_multiple_files_hardly()
{
$this->setup->create_directories();
$user = User::factory(User::class)
->create();
@@ -294,46 +285,4 @@ class FileTest extends TestCase
);
});
}
/**
* @test
*/
public function it_zip_multiple_files_and_download_it()
{
$this->setup->create_directories();
$user = User::factory(User::class)
->create();
Sanctum::actingAs($user);
collect([0, 1])
->each(function ($index) {
$file = UploadedFile::fake()
->create("fake-file-$index.pdf", 1200, 'application/pdf');
$this->postJson('/api/upload', [
'filename' => $file->name,
'file' => $file,
'folder_id' => null,
'is_last' => true,
])->assertStatus(201);
});
$file_ids = File::all()->pluck('id');
$this->postJson("/api/zip/files", [
'items' => $file_ids,
])->assertStatus(201);
$this->assertDatabaseHas('zips', [
'user_id' => $user->id
]);
Storage::disk('local')
->assertExists(
'zip/' . Zip::first()->basename
);
}
}