테스트는 애플리케이션이 의도한 대로 작동하는지 확인하는 소프트웨어 개발의 중요한 측면입니다. Laravel은 널리 사용되는 PHP 테스트 프레임워크인 PHPUnit을 통해 강력한 테스트 제품군을 즉시 제공합니다. 이 가이드는 Laravel에서 테스트를 설정하고 실행하는 과정을 안내하고, 단위 테스트와 기능 테스트의 차이점을 설명하고, 다양한 테스트 시나리오에 대한 예제를 제공합니다.
Laravel에서 테스트는 일반적으로 Unit과 Feature라는 두 개의 주요 디렉터리로 구성됩니다.
단위 테스트: 이 테스트는 개별 메서드나 클래스와 같이 애플리케이션의 작고 분리된 부분을 테스트하도록 설계되었습니다. 일반적으로 test/Unit 디렉토리에 있습니다. 각 테스트 기능은 test라는 단어로 시작해야 합니다.
예:
public function testExampleFunction() { $this->assertTrue(true); }
기능 테스트: 이 테스트는 보다 복잡한 상호 작용을 처리하며 일반적으로 함께 작동하는 여러 구성 요소를 테스트합니다. 테스트/기능 디렉터리에 있습니다. 기능 테스트에는 HTTP 요청 및 응답 확인이 포함되는 경우가 많습니다.
Laravel 애플리케이션에서 모든 테스트를 실행하려면 다음 명령을 사용하세요.
./vendor/bin/phpunit
테스트를 실행하기 전에 테스트 환경을 구성하는 것이 중요합니다. 테스트용 환경 변수를 설정하려면 phpunit.xml 파일을 수정하세요. 예를 들어 더 빠른 테스트를 위해 SQLite 인메모리 데이터베이스를 사용하려면 다음을 수행하세요.
<php> <env name="APP_ENV" value="testing"></env> <env name="APP_MAINTENANCE_DRIVER" value="file"></env> <env name="BCRYPT_ROUNDS" value="4"></env> <env name="CACHE_STORE" value="array"></env> <env name="DB_CONNECTION" value="sqlite"></env> <env name="DB_DATABASE" value=":memory:"></env> <env name="MAIL_MAILER" value="array"></env> <env name="PULSE_ENABLED" value="false"></env> <env name="QUEUE_CONNECTION" value="sync"></env> <env name="SESSION_DRIVER" value="array"></env> <env name="TELESCOPE_ENABLED" value="false"></env> </php>
SQLite를 테스트 환경으로 활성화한 후 구성 캐시를 지웁니다.
php artisan config:clear
*예: 프로필 경로가 존재하고 올바르게 작동하는지 테스트
*
프로필 경로에 대한 테스트 만들기:
php artisan make:test ProfileTest
프로필 페이지에 특정 텍스트가 표시되는지 확인하는 테스트 방법을 추가하세요.
public function testProfilePage(){ $response = $this->get('/profile'); $response->assertSeeText('Your Profile'); }
테스트 데이터베이스 설정
데이터베이스 상호 작용을 테스트하기 전에 config/database.php에서 테스트 데이터베이스 구성을 생성하세요.
'mysqltesting' => [ 'driver' => 'mysql', 'url' => env('DB_URL'), 'host' => env('DB_HOST', '127.0.0.1'), 'port' => env('DB_PORT', '3306'), 'database' => 'laravel_testing', 'username' => env('DB_USERNAME', 'root'), 'password' => env('DB_PASSWORD', ''), 'unix_socket' => env('DB_SOCKET', ''), 'charset' => 'utf8mb4', 'collation' => 'utf8mb4_unicode_ci', 'prefix' => '', 'prefix_indexes' => true, 'strict' => true, 'engine' => null, 'options' => extension_loaded('pdo_mysql') ? array_filter([ PDO::MYSQL_ATTR_SSL_CA => env('MYSQL_ATTR_SSL_CA'), ]) : [], ],
데이터베이스 테스트 실행
PHPUnit 명령을 실행하여 테스트 데이터베이스가 생성되고 작동하는지 확인하세요.
./vendor/bin/phpunit
사용자 등록 테스트 만들기:
php artisan make:test UserTest
사용자를 생성하고 데이터베이스에 저장할 수 있는지 확인하는 테스트 방법을 추가하세요.
public function test_registration(): void { $user = new User(); $user->name = 'Test User'; $user->email = 'email@example.com'; $user->password = bcrypt('password'); $user->save(); $this->assertDatabaseHas('users', ['email' => 'email@example.com']); }
PostTest 클래스에서 상점 작업에 대한 테스트를 만듭니다.
public function testPostStoreValid() { $data = [ 'title'=> 'Test Post', 'slug' => 'test-post', 'content' => 'Content of the post', 'active' => true, ]; $this->post('/posts', $data) ->assertStatus(302) ->assertSessionHas('status'); $this->assertEquals(session('status'), 'Post was created!'); }
유효성 검사 오류를 확인하는 테스트 방법을 추가하세요.
public function testPostFail() { $data = [ 'title'=> '', 'content' => '', ]; $this->post('/posts', $data) ->assertStatus(302) ->assertSessionHas('errors'); $messages = session('errors')->getMessages(); $this->assertEquals($messages['title'][0], 'The title must be at least 4 characters.'); $this->assertEquals($messages['title'][1], 'The title field is required.'); $this->assertEquals($messages['content'][0], 'The content field is required.'); }
*업데이트 작업 테스트
*
게시물 업데이트를 위한 테스트 방법 추가:
public function testPostUpdate() { $post = new Post(); $post->title = "Initial Title"; $post->slug = Str::slug($post->title, '-'); $post->content = "Initial content"; $post->active = true; $post->save(); $this->assertDatabaseHas('posts', $post->toArray()); $data = [ 'title' => 'Updated Title', 'slug' => 'updated-title', 'content' => 'Updated content', 'active' => false, ]; $this->put("/posts/{$post->id}", $data) ->assertStatus(302) ->assertSessionHas('status'); $this->assertDatabaseHas('posts', ['title' => $data['title']]); $this->assertDatabaseMissing('posts', ['title' => $post->title]); }
삭제 작업 테스트
게시물 삭제를 위한 테스트 방법 추가:
public function testPostDelete() { $post = new Post(); $post->title = "Title to delete"; $post->slug = Str::slug($post->title, '-'); $post->content = "Content to delete"; $post->active = true; $post->save(); $this->assertDatabaseHas('posts', $post->toArray()); $this->delete("/posts/{$post->id}") ->assertStatus(302) ->assertSessionHas('status'); $this->assertDatabaseMissing('posts', $post->toArray()); }
**
**
특정 테스트 메서드나 클래스를 실행하려면 PHPUnit과 함께 --filter 옵션을 사용하세요. 다음은 몇 가지 예입니다.
특정 테스트 방법 실행
./vendor/bin/phpunit --filter PostTest::testPostDelete
특정 클래스의 모든 테스트 실행
./vendor/bin/phpunit --filter PostTest
특정 파일에서 테스트 실행
./vendor/bin/phpunit tests/Feature/PostTest.php
자세한 출력
더 자세한 출력을 보려면 -v 옵션을 추가하세요.
./vendor/bin/phpunit --filter PostTest::testPostDelete -v
위 내용은 PHPUnit을 사용하여 Laravel에서 테스트하기 위한 종합 가이드의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!