1. 什么是webman和单元测试
Webman 是基于已有 PHP Swoole 扩展的高性能 PHP 开发框架,同时支持传统的 PHP-FPM 和 Swoole 单进程模式,无需更改一行业务代码即可完成2种方式的服务端部署,并且提供了 HTTP、WebSocket、TCP、UDP、UnixSocket、MQTT 等多种服务端协议,以及 Task、Timer、Process 等服务端功能。
单元测试是对软件中的最小可测试单元进行检查和验证的一种测试方法。单元测试的意义在于为软件开发提供强有力的支持,保证代码的质量,为重构程序、分析问题提供保障,保证程序的正确性。
使用 Webman 进行开发时,单元测试是非常重要的一环,可以使得代码更加稳定,开发效率更高。
2. 配置 PHPUnit
2.1 安装 PHPUnit
在终端中使用以下命令进行安装:
$ composer require --dev phpunit/phpunit
2.2 配置 PHPUnit
在项目的根目录下创建 phpunit.xml 文件:
<phpunit bootstrap="vendor/autoload.php">
<testsuites>
<testsuite name="Test Suite">
<directory>tests</directory>
</testsuite>
</testsuites>
</phpunit>
其中,bootstrap
设置为 vendor/autoload.php
,directory
设置为存放测试用例的目录。
2.3 编写测试用例
在项目根目录下创建 tests 目录,存放测试用例。
以下是一个简单的测试用例:
<?php
use PHPUnit\Framework\TestCase;
class ExampleTest extends TestCase
{
public function testAdd()
{
$this->assertEquals(2, 1 + 1);
}
}
3. 配置 phpStorm
3.1 安装 phpStorm
在官网上下载并安装 phpStorm。
3.2 配置 phpStorm
打开 phpStorm,进入 Settings -> Languages & Frameworks -> PHP -> Test Frameworks。
3.3 配置 PHPUnit
点击 + 进行新增 PHPUnit。
配置 PHPUnit 的路径:选择 Use Composer autoloader 并填写 vendor/autoload.php 的路径。
配置 PHPUnit 的配置文件:选择 Use custom configuration file 并填写 phpunit.xml 的路径。
点击 OK 完成 PHPUnit 配置。
3.4 运行单元测试
在 phpStorm 中右键单击测试用例文件或目录,选择 Run 'PHPUnit in ...' 进行单元测试。
4. 配置 webman
4.1 安装 webman
在终端中使用以下命令进行安装:
$ composer require wenbinye/webman-testing --dev
4.2 编写测试用例
以下是一个简单的测试用例(单元测试 Webman 中的 Controller):
<?php
use Wenbinye\WebmanTesting\WebmanTestCase;
class ExampleTest extends WebmanTestCase
{
public function testExample()
{
$response = $this->get('/index/hello');
$this->assertEquals(200, $response->getStatusCode());
$this->assertContains('Hello webman', $response->getBody()->getContents());
}
}
其中,使用 Webman 提供的 WebmanTestCase 作为测试用例。
4.3 运行单元测试
在终端中使用以下命令进行单元测试:
$ phpunit
单元测试结果会在终端中输出。
也可以在 phpStorm 中使用同样的方式进行单元测试。
总结
Webman 和 PHPUnit 的结合可以使开发效率更高,并且使得代码更加稳定。
在使用 phpStorm 进行开发时,可以方便地配置 PHPUnit。
在编写测试用例时,需要注意测试用例的质量,同时可以使用 Webman 提供的 WebmanTestCase 来方便地测试 Webman 中的 Controller。