在进行 php 单元测试时,我们经常需要模拟一些依赖对象,以便隔离被测试的代码。NULL Object 是一种常用的设计模式,它提供了一个具有相同接口但什么都不做的对象,用于替代那些在特定测试场景下不需要实际功能的依赖对象。
手动创建 null object 是一项重复且繁琐的任务。为了解决这个问题,我发现了一个非常有用的 php 库:koriym/null-object。这个库可以根据接口自动生成 null object,极大地简化了单元测试的编写过程。
koriym/null-object 的主要功能是:
- 根据接口生成 Null Object: 自动创建一个实现了指定接口的 Null Object 类。
- 支持动态创建和保存到文件: 可以动态创建 Null Object,也可以将生成的代码保存到文件中。
- On-the-fly 模式: 通过注册自动加载器,可以简单地通过在接口名称后添加 Null 后缀来创建 Null Object。
安装
使用 composer 安装 koriym/null-object 非常简单:
立即学习“PHP免费学习笔记(深入)”;
composer require --dev koriym/null-object
使用示例
假设我们有以下接口:
interface FooInterface { public function doSomething(): void; public function getValue(): string; }
使用 koriym/null-object 可以这样生成 Null Object:
use KoriymNullObjectNullObject; class MyTest extends TestCase { private NullObject $nullObject; protected function setUp(): void { $this->nullObject = new NullObject(); } public function testNullObject(): void { $nullObject = $this->nullObject->newInstance(FooInterface::class); $this->assertInstanceOf(FooInterface::class, $nullObject); $nullObject->doSomething(); // 什么都不会发生 $this->assertSame('', $nullObject->getValue()); // 返回默认值 } }
On-the-fly 模式
koriym/null-object 还提供了一种更便捷的 On-the-fly 模式。首先,需要在 composer.json 中注册自动加载器:
"autoload-dev": { "files": ["./vendor/koriym/null-object/autoload.php"] }
然后,就可以直接通过在接口名称后添加 Null 后缀来创建 Null Object:
$nullClass = FooInterface::class . 'Null'; $foo = new $nullClass; $this->assertInstanceOf(FooInterface::class, $foo);
总结
koriym/null-object 是一个非常实用的 PHP 库,可以帮助我们快速生成 Null Object,从而简化单元测试的编写过程,提高开发效率。其 On-the-fly 模式更是方便快捷,值得在项目中尝试使用。
优点:
- 快速生成 Null Object,减少重复代码。
- 提高单元测试效率。
- On-the-fly 模式使用方便。
缺点:
- 不支持继承的接口。
总的来说,koriym/null-object 是一个值得推荐的 PHP 单元测试辅助工具。
© 版权声明
文章版权归作者所有,未经允许请勿转载。
THE END