> 백엔드 개발 > PHP 튜토리얼 > Pest를 사용하여 Laravel에서 테스트 케이스를 만드는 방법

Pest를 사용하여 Laravel에서 테스트 케이스를 만드는 방법

WBOY
풀어 주다: 2024-08-06 07:13:42
원래의
1014명이 탐색했습니다.

How to Create a Test Case in Laravel Using Pest

Laravel 애플리케이션을 테스트하는 것은 코드가 예상대로 작동하는지 확인하는 데 중요합니다. Pest는 최소한의 사용자 친화적으로 설계된 PHP용 테스트 프레임워크입니다. 이 블로그 게시물에서는 Pest를 사용하여 Laravel에서 테스트 케이스를 생성하는 방법을 살펴보고, 로고 업로드를 포함하여 고용주 레코드 생성을 테스트하는 예제에 중점을 둘 것입니다.

전제조건

  • Laravel 애플리케이션 설정
  • Laravel 애플리케이션에 설치된 Pest

아직 Pest를 설치하지 않았다면 공식 Pest 설치 가이드를 따라 설치하세요.

1단계: 모델 및 관계 설정

사용자 및 고용주 모델이 필요한 관계로 올바르게 설정되었는지 확인하세요.

사용자 모델(app/Models/User.php):

namespace App\Models;

use Illuminate\Foundation\Auth\User as Authenticatable;
use Illuminate\Database\Eloquent\Relations\HasOne;

class User extends Authenticatable
{
    public function employer(): HasOne
    {
        return $this->hasOne(Employer::class);
    }
}

로그인 후 복사

고용주 모델(app/Models/Employer.php):

namespace App\Models;

use Illuminate\Database\Eloquent\Model;
use Illuminate\Database\Eloquent\Relations\BelongsTo;

class Employer extends Model
{
    protected $fillable = ['name', 'email', 'phone', 'address', 'city', 'website', 'user_id', 'logo'];

    public function user(): BelongsTo
    {
        return $this->belongsTo(User::class);
    }
}
로그인 후 복사

2단계: 공장 설립

테스트 데이터 생성을 위한 팩토리를 생성하세요.

사용자 팩토리(database/factories/UserFactory.php):

namespace Database\Factories;

use App\Models\User;
use Illuminate\Database\Eloquent\Factories\Factory;
use Illuminate\Support\Str;

class UserFactory extends Factory
{
    protected $model = User::class;

    public function definition()
    {
        return [
            'name' => $this->faker->name(),
            'email' => $this->faker->unique()->safeEmail(),
            'email_verified_at' => now(),
            'password' => bcrypt('password'), // password
            'remember_token' => Str::random(10),
        ];
    }
}

로그인 후 복사

고용주 공장(데이터베이스/factories/EmployerFactory.php):

namespace Database\Factories;

use App\Models\Employer;
use Illuminate\Database\Eloquent\Factories\Factory;
use Illuminate\Http\UploadedFile;

class EmployerFactory extends Factory
{
    protected $model = Employer::class;

    public function definition()
    {
        return [
            'name' => $this->faker->company,
            'email' => $this->faker->companyEmail,
            'phone' => $this->faker->phoneNumber,
            'address' => $this->faker->address,
            'city' => $this->faker->city,
            'website' => $this->faker->url,
            UploadedFile::fake()->image('logo.png')
        ];
    }
}

로그인 후 복사

3단계: 컨트롤러 작성

Employer 생성을 처리하는 컨트롤러 메서드를 만듭니다.

고용주 컨트롤러(app/Http/Controllers/EmployerController.php):

namespace App\Http\Controllers;

use Illuminate\Http\Request;
use App\Models\Employer;
use Illuminate\Support\Facades\Storage;

class EmployerController extends Controller
{
    public function __construct()
    {

    }

    public function store(Request $request)
    {
        $validated = $request->validate([
            'name' => 'required|string|max:255',
            'email' => 'required|email',
            'phone' => 'required|string',
            'address' => 'nullable|string',
            'city' => 'nullable|string',
            'website' => 'nullable|url',
            'logo' => 'nullable|image|mimes:jpeg,png,jpg,gif,svg|max:2048',
        ]);

        if ($request->hasFile('logo')) {
            $path = $request->file('logo')->store('logos', 'public');
            $validated['logo'] = $path;
        }

        $employer = $request->user()->employer()->create($validated);

        return response()->json($employer, 201);
    }
}

로그인 후 복사

4단계: 해충 테스트 생성

로고 업로드를 포함하여 고용주 생성을 확인하기 위해 테스트 파일을 생성하고 테스트 사례를 작성합니다.

테스트 파일 만들기:

php artisan pest:test EmployerControllerTest
로그인 후 복사

테스트 사례 작성(tests/Feature/EmployerControllerTest.php):

<?php

use Illuminate\Foundation\Testing\RefreshDatabase;
use Illuminate\Support\Facades\Auth;
use App\Models\User;
use App\Models\Employer;
use Illuminate\Http\UploadedFile;
use Illuminate\Support\Facades\Storage;

uses(RefreshDatabase::class);

it('prevents guests from creating an employer', function () {
    // Define the data to be sent in the POST request
    $data = [
        'name' => 'Test Employer',
        'email' => 'test@employer.com',
        'phone' => '1234567890',
        'address' => '123 Employer St',
        'city' => 'Employer City',
        'website' => 'https://www.employer.com',
    ];

    // Send the POST request to create the employer as a guest (unauthenticated)
    $response = $this->post('/api/employers', $data);

    // Assert that the response status is 401 (Unauthorized)
    $response->assertStatus(401);

    // Optionally, check that the employer was not created
    $this->assertDatabaseMissing('employers', [
        'name' => 'Test Employer',
        'email' => 'test@employer.com',
    ]);
});

it('creates a new employer for authenticated user', function () {
    // Create a user and log them in
    $user = User::factory()->create();
    Auth::login($user);

    // Define the data to be sent in the POST request
    $data = [
        'name' => 'Test Employer',
        'email' => 'test@employer.com',
        'phone' => '1234567890',
        'address' => '123 Employer St',
        'city' => 'Employer City',
        'website' => 'https://www.employer.com',
    ];

    // Send the POST request to create the employer
    $response = $this->post('/api/employers', $data);

    // Assert that the response status is 201 (Created)
    $response->assertStatus(201);

    // Assert that the employer was created
    $this->assertDatabaseHas('employers', [
        'name' => 'Test Employer',
        'email' => 'test@employer.com',
    ]);
});

it('creates a new employer with a logo', function () {
    // Create a user and log them in
    $user = User::factory()->create();
    Auth::login($user);

    // Fake a storage disk for testing
    Storage::fake('public');

    // Define the data to be sent in the POST request
    $data = [
        'name' => 'Test Employer',
        'email' => 'test@employer.com',
        'phone' => '1234567890',
        'address' => '123 Employer St',
        'city' => 'Employer City',
        'website' => 'https://www.employer.com',
        'logo' => UploadedFile::fake()->image('logo.png'), // Fake file for testing
    ];

    // Send the POST request to create the employer
    $response = $this->post('/api/employers', $data);

    // Assert that the response status is 201 (Created)
    $response->assertStatus(201);

    // Optionally, check if the employer was actually created
    $this->assertDatabaseHas('employers', [
        'name' => 'Test Employer',
        'email' => 'test@employer.com',
    ]);

    // Check that the file was uploaded
    Storage::disk('public')->assertExists('logos/logo.png'); // Adjust path as needed
});

로그인 후 복사

5단계: 해충 테스트 실행
해충 테스트를 실행하여 모든 것이 예상대로 작동하는지 확인하세요.

php artisan test --testsuit=Feature
로그인 후 복사

결론

다음 단계에 따라 Pest를 사용하여 Laravel에서 테스트 사례를 생성하여 파일 업로드 처리를 포함하여 고용주 레코드 생성을 확인할 수 있습니다. 이 접근 방식을 사용하면 애플리케이션이 예상대로 작동하고 개발 프로세스 초기에 문제를 포착하는 데 도움이 됩니다. 즐거운 테스트 되세요!

위 내용은 Pest를 사용하여 Laravel에서 테스트 케이스를 만드는 방법의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

원천:dev.to
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿