PHP의 단위 테스트 도구인 PHPUnit의 사용법에 대해 이야기해 보겠습니다.
单元测试是指对软件中的最小可测试单元进行检查和验证。本篇文章带大家了解一下php如何实现单元测试,介绍一下安装单元测试工具PHPUnit并使用的方法。
朋友,你听说过安。。。不是,写过单元测试吗。
单元测试是开发过程中必不可少的一环,一个项目有良好的单元测试代码,重构的勇气都大很多。这次写一篇小文来介绍一下 PHP 的单元测试工具 PHPUnit 的使用。
PHPUnit 的使用并不难,这篇文章主要还是充当一个引子,介绍基本概念和使用,有了这篇文章的基础之后,去看官网的文档就会更加顺风顺水。
安装
安装 PHPUnit 的方式很简单,使用 composer 可以一行代码就可以安装。
composer require --dev phpunit/phpunit
安装之后,在 vendor/bin
目录下有一个 phpunit 的可执行文件,这个就是 phpunit 本体了。假设我们项目的目录结构如下:
➜ phpunit tree . ├── controller ├── model ├── service ├── test └── vendor ├── composer.json
其中我们的单元测试代码都放在 test 目录下。使用 composer 来为我们解决 autoload 的问题。
{ "autoload": { "psr-4": { "Controller\\": "controller/", "Model\\": "model/", "Service\\": "service/", "Test\\": "test/", } }, }
如果你还不懂 composer 自动加载的使用,可以参考这篇文章。最后执行 composer dumpautoload -o
让自动加载生效。
到这里我们的安装就算结束了。如果你使用 phpstorm 进行开发,那么你需要进行如下的配置:
这里指明了从哪里加载 PHPUnit,由于我们使用 composer 安装,所以,这里的文件选择 composer 生成的 autoload.php 文件即可。
使用
好了,假设我们现在进行开发,在 service 目录中添加了一个 CalculateService
的文件,并且编写了一个 abs 的函数。
namespace Service; class CalculateService { public function abs($num) { return abs($num); } }
现在我们对 abs
函数进行单元测试,PHPUnit 规定了一个测试类必须遵守如下的规定:
- 单元测试类名必须以 Test 结尾,必须继承
\PHPUnit\Framework\TestCase
基类。 - 每个测试函数必须以 test 开头。
上面的规定是必须遵守的,如果代码没有遵守规定 PHPUnit 不会把他当做单元测试代码。除了以上的两条,还有一些良好的编码习惯可以参考:
- 单元测试代码都放在 test 目录下。
- 每个单元测试类以被测试的类名开头。例如被测试类为
CalculateService
,那么单元测试类应该为CalculateServiceTest
。 - 每个单元测试函数应该为被测试函数名结尾。例如被测试函数为
abs
,那么单元测试函数应该为testAbs
。
根据上面的规范,编写单元测试代码
class UserServiceTest extends \PHPUnit\Framework\TestCase { public function testAbs() { $userService = new \Service\CalculateService(); $this->assertEquals(4, $userService->abs(4)); } }
在上面的测试代码中,调用了我们要测试的函数 abs
,然后断言 $userService->abs(4)
的结果为 4。在 phpstorm 中直接在 testAbs
函数处右键选择 run UserServiceTest
执行:
发现在控制台会输出如下内容
Time: 17 ms, Memory: 4.00MB OK (1 test, 1 assertion)
表明 abs
通过了 $userService->abs(4) == 4
的测试用例。这里注意一点,这里并不表明 abs
函数已经通过测试,一个良好的测试应该包含多个测试用例来覆盖尽可能多的可能性。
现在 PHPUnit 基本的单元测试已经运行成功了,在 PHPUnit 的文档中,有更多关于测试的用法。由于 PHPUnit 的用法过多,这里不能一一说明,这里提一些其他用法。
PHPUnit 提供了
@test
的注解,如果一个测试函数添加了@test
注解,那么测试函数名字就不必以 test 开头。\PHPUnit\Framework\TestCase
有一个setUp
函数,如果自己编写的测试类重写了这个函数,那么每次在开始执行测试函数之前,会先执行setUp
进行测试之前的初始化。同样,也有一个tearDown
的函数,如果重写,那么在测试函数执行完毕之后调用tearDown
函数。.... 更多的内容需参考 PHPUnit 的文档。
phpunit.xml 文件
在上面的例子中,我们使用 phpstorm 逐个执行测试函数,但是如果我们需要一次性执行所有的单元测试,那么我们可以编写 phpunit.xml 文件来实现。
给出一个 phpunit.xml 的编写例子来讲解 phpunit.xml 的作用
<?xml version="1.0" encoding="UTF-8"?> <phpunit> <testsuites> <testsuite> <directory>test</directory> </testsuite> </testsuites> </phpunit>
这里 <directory>test</directory>
指定了测试代码都放在 test 目录下,在 phpstorm 下右键点击 phpunit.xml 文件选择 Run phpunit.xml
,phpunit 就会到 test 目录下查找所有单元测试并逐个执行。
除了使用 phpunit.xml 来一次性执行所有的单元测试,还可以在 phpunit.xml 中配置单元测试结果的输出日志。
<?xml version="1.0" encoding="UTF-8"?> <phpunit> ..... <logging> <log type="testdox-html" target="tmp/log.html"/> </logging> </phpunit>
此时在执行 phpunit.xml 文件,就会在项目目录下生成一个 tmp/log.html
文件,这个文件记录了所有单元测试的结果。
当然,,,更多 phpunit.xml 配置相关的内容,还是需要查看文档。 :laughing:
Mock 测试
PHPUnit 还提供了 Mock 测试。这里先介绍一下什么是 Mock 测试。
假设 foo 函数调用了 bar 函数,那么在对 foo 函数进行单元测试会有两个问题:
- foo 函数依赖于 bar 函数的结果,那么在对 foo 进行单元测试的时候必然会引入 bar ,那么这样子单元测试就没意义了,如果测试不通过,那么无法保证 bug 出在 foo 还是 bar。
- bar 函数可能在测试环境不可执行,那么 foo 无法获取 bar 的执行结果,从而无法对 foo 进行单元测试。
Mock 测试就是为了解决上面的问题而出现的,使用 Mock 我们可以虚拟出一个 bar 的调用,并且假设 bar 调用返回结果。如果还是听不懂,上一段代码就知道了。
class MockTest extends \PHPUnit\Framework\TestCase { public function testGet() { $stub = $this->createMock(\App\UserService::class); //1 $stub->method('get')->willReturn(3); //2 $this->assertEquals(3,$stub->get(1)); //3 } }
上面的测试函数就使用到了 Mock,一行一行代码来分析:
- 第一行创建了一个虚拟的
UserService
对象。 - 第二行假设
UserService
中的get
函数的返回值为 3。 - 第三行调用
$stub->get(1)
不会真的去执行get
函数,而是根据第二行的willReturn
函数直接返回 3。
以上就是一个简单的 Mock 测试,当然 Mock 测试还有很多复杂的用法,这里没办法一一展开,其实掌握基本的用法,更多复杂的高级用法在实践中碰到了再去查看文档也不迟。
好了,PHPUnit 的基本操作就这些了,单元测试本身并不是一个很难的东西,阻碍单元测试的进行并不是在技术上,更多的是一个项目时间安排的衡量与考虑。
推荐学习:《PHP视频教程》
위 내용은 PHP의 단위 테스트 도구인 PHPUnit의 사용법에 대해 이야기해 보겠습니다.의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

핫 AI 도구

Undresser.AI Undress
사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover
사진에서 옷을 제거하는 온라인 AI 도구입니다.

Undress AI Tool
무료로 이미지를 벗다

Clothoff.io
AI 옷 제거제

AI Hentai Generator
AI Hentai를 무료로 생성하십시오.

인기 기사

뜨거운 도구

메모장++7.3.1
사용하기 쉬운 무료 코드 편집기

SublimeText3 중국어 버전
중국어 버전, 사용하기 매우 쉽습니다.

스튜디오 13.0.1 보내기
강력한 PHP 통합 개발 환경

드림위버 CS6
시각적 웹 개발 도구

SublimeText3 Mac 버전
신 수준의 코드 편집 소프트웨어(SublimeText3)

뜨거운 주제











PHP 8.4는 상당한 양의 기능 중단 및 제거를 통해 몇 가지 새로운 기능, 보안 개선 및 성능 개선을 제공합니다. 이 가이드에서는 Ubuntu, Debian 또는 해당 파생 제품에서 PHP 8.4를 설치하거나 PHP 8.4로 업그레이드하는 방법을 설명합니다.

CakePHP는 PHP용 오픈 소스 프레임워크입니다. 이는 애플리케이션을 훨씬 쉽게 개발, 배포 및 유지 관리할 수 있도록 하기 위한 것입니다. CakePHP는 강력하고 이해하기 쉬운 MVC와 유사한 아키텍처를 기반으로 합니다. 모델, 뷰 및 컨트롤러 gu

VS Code라고도 알려진 Visual Studio Code는 모든 주요 운영 체제에서 사용할 수 있는 무료 소스 코드 편집기 또는 통합 개발 환경(IDE)입니다. 다양한 프로그래밍 언어에 대한 대규모 확장 모음을 통해 VS Code는

CakePHP는 오픈 소스 MVC 프레임워크입니다. 이를 통해 애플리케이션 개발, 배포 및 유지 관리가 훨씬 쉬워집니다. CakePHP에는 가장 일반적인 작업의 과부하를 줄이기 위한 여러 라이브러리가 있습니다.

이 튜토리얼은 PHP를 사용하여 XML 문서를 효율적으로 처리하는 방법을 보여줍니다. XML (Extensible Markup Language)은 인간의 가독성과 기계 구문 분석을 위해 설계된 다목적 텍스트 기반 마크 업 언어입니다. 일반적으로 데이터 저장 AN에 사용됩니다

JWT는 주로 신분증 인증 및 정보 교환을 위해 당사자간에 정보를 안전하게 전송하는 데 사용되는 JSON을 기반으로 한 개방형 표준입니다. 1. JWT는 헤더, 페이로드 및 서명의 세 부분으로 구성됩니다. 2. JWT의 작업 원칙에는 세 가지 단계가 포함됩니다. JWT 생성, JWT 확인 및 Parsing Payload. 3. PHP에서 인증에 JWT를 사용하면 JWT를 생성하고 확인할 수 있으며 사용자 역할 및 권한 정보가 고급 사용에 포함될 수 있습니다. 4. 일반적인 오류에는 서명 검증 실패, 토큰 만료 및 대형 페이로드가 포함됩니다. 디버깅 기술에는 디버깅 도구 및 로깅 사용이 포함됩니다. 5. 성능 최적화 및 모범 사례에는 적절한 시그니처 알고리즘 사용, 타당성 기간 설정 합리적,

문자열은 문자, 숫자 및 기호를 포함하여 일련의 문자입니다. 이 튜토리얼은 다른 방법을 사용하여 PHP의 주어진 문자열의 모음 수를 계산하는 방법을 배웁니다. 영어의 모음은 A, E, I, O, U이며 대문자 또는 소문자 일 수 있습니다. 모음이란 무엇입니까? 모음은 특정 발음을 나타내는 알파벳 문자입니다. 대문자와 소문자를 포함하여 영어에는 5 개의 모음이 있습니다. a, e, i, o, u 예 1 입력 : String = "Tutorialspoint" 출력 : 6 설명하다 문자열의 "Tutorialspoint"의 모음은 u, o, i, a, o, i입니다. 총 6 개의 위안이 있습니다

숙련된 PHP 개발자라면 이미 그런 일을 해왔다는 느낌을 받을 것입니다. 귀하는 상당한 수의 애플리케이션을 개발하고, 수백만 줄의 코드를 디버깅하고, 여러 스크립트를 수정하여 작업을 수행했습니다.
