저는 2015년 중반부터 순수 PHP를 배우기 시작했습니다. 그러다가 CodeIgniter 3와 Laravel 5.1에 익숙해졌습니다. 수년 동안 Laravel은 제가 선택한 프레임워크였으며 저는 여전히 이를 고수하고 있습니다. 다른 인기 있는 PHP 프로젝트와 마찬가지로 PHPUnit은 단위 테스트를 위한 유일한 선택이라고 생각합니다. 하지만 2021년 페스트가 찾아오면서 약간의 변화가 있었습니다. 이는 PHP 및 Laravel 커뮤니티에서 널리 사용되는 수많은 훌륭한 프로젝트/패키지를 만드는 Laravel의 엔지니어인 Nuno Maduro가 만들었습니다.
Pest의 첫날부터 PHPUnit이면 충분하고 이 새로운 테스트 도구를 배우기가 게으르기 때문에 걱정하지 않았습니다. 그러나 Laravel 커뮤니티가 성장할수록 Pest를 권장하는 경우도 많아집니다. Spatie, Livewire, Filament 등의 많은 Laravel 프로젝트/패키지는 Pest를 사용합니다. 그래서 문제는 그들과 관련된 것들을 테스트할 때 PHPUnit으로 포팅해야 한다는 것입니다. 선택의 여지가 없는 것 같아요. 이제 페스트를 살펴보는 시간이 왔습니다.
설치 섹션에 이어 Pest를 사용하여 첫 번째 PHP 프로젝트를 만듭니다.
mkdir ~/Herd/lerning-pest cd ~/Herd/learning-pest composer require pestphp/pest --dev --with-all-dependencies ./vendor/bin/pest --init
디렉토리 구조는 PHPUnit과 거의 동일합니다. 다른 점은 테스트가 어떻게 보이는가입니다. 클래스 기반이 아닌 클로저 기반입니다.
<?php // tests/Unit/ExampleTest.php test('example', function () { expect(true)->toBeTrue(); });
나는 런타임에 객체에 메서드를 느리게 연결할 수 있는 Closure를 사용하는 것을 알고 있습니다. 따라서 이것은 PHPUnit에서 이렇게 다시 작성될 수 있습니다.
<?php // tests/Unit/ExampleTest.php class ExampleTest extends \PHPUnit\Framework\TestCase { public function test_example() { $this->assertTrue(true); } }
Pest 어설션 구문은 Ruby의 Rspec 및 Jest에서 영감을 받았다고 하는데, 잘 모르겠습니다. 그래서 나도 그들에게 별로 관심이 없다. 나에게는 어설션 구문이 어떻게 되는지는 중요하지 않습니다.
테스트를 실행할 때 표시되는 결과가 마음에 듭니다. PHPUnit보다 훨씬 예쁘고 깔끔한 것 같아요.
제가 PHPUnit에서 가장 많이 사용한 어설션입니다.
$this->assertSame($expected, $actual); $this->assertTrue($condition); $this->assertFalse($condition); $this->assertNull($actual); $this->assertEmpty($array); $this->assertCount($count, $countable); $this->assertInstanceof($type, $instance);
Pest에서는 쉽게 다시 작성할 수 있습니다.
expect($actual)->toBe($expected); expect($condition)->toBeTrue(); expect($condition)->toBeFalse(); expect($actual)->toBeNull(); expect($actual)->toBeEmpty(); expect($actual)->toBeInstanceOf($type);
앞서 언급했듯이 Pest 어설션 구문은 괜찮지만, 새로운 API를 공부할 필요가 없기 때문에 현재는 PHPUnit을 고수하고 있습니다. 어쨌든 저는 PHPUnit 어설션을 선호하고 Pest에서 고유한 것만 사용합니다. 아키텍처 테스트가 그 예입니다. 내 테스트 파일은 다음과 같습니다.
<?php test("all PHP files in LearningPest namespace must have strict mode enabled", function () { arch() ->expect('LearningPest') ->toUseStrictTypes(); }); test('all PHPUnit assertions are available for Pest', function () { $instance = new \stdClass(); $getInstance = function () use ($instance) { return $instance; }; $this->assertSame($instance, $getInstance()); $this->assertInstanceOf(stdClass::class, $instance); $this->assertTrue(1 < 2); $this->assertFalse(1 > 2); $value = null; $this->assertNull($value); $this->assertEmpty([]); $array = [1, 2, 3]; $this->assertCount(3, $array); });
PHPUnit과 동일하게 Pest에서 작업할 수 있는 필수 기능이 많이 있습니다. 여기 있습니다:
Mockery는 독립형 라이브러리이므로 여기에 나열하지 않습니다.
반면에 Pest에는 아키텍처, 스냅샷, 스트레스 테스트, 플러그인 등 유용한 기능이 많이 있습니다. 테스트를 작성할 때 발견하겠습니다.
Pest를 사용해본 적이 없는 PHP 개발자라면 꼭 사용해 보세요.
위 내용은 마침내 PHP와 Laravel용 Pest를 사용해 본 후 전환했습니다.의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!