gamez/psr-testlogger
最新稳定版本:3.0.0
Composer 安装命令:
composer require gamez/psr-testlogger
包简介
PSR-3 compliant test logger for developers who like tests and want to check if their application logs messages as they expect.
README 文档
README
PSR-3 compliant test logger for developers who like tests and want to check if their application logs messages as they expect.
This package was superseded by beste/psr-testlogger.
Installation
composer require --dev gamez/psr-testlogger
Usage
Inject an instance of Gamez\Psr\Log\TestLogger into your Subject Under Test
instead of your regular logger.
use Psr\Log\LoggerInterface; class SubjectUnderTest { public function __construct(LoggerInterface $logger) { $this->logger = $logger; } public function execute() { $this->logger->info('Message with a {placeholder}', ['placeholder' => 'value']); $this->logger->emergency('This {placeholder} will not be replaced.'); } }
use Gamez\Psr\Log\TestLogger; use PHPUnit\Framework\TestCase; class MyTest extends TestCase { /** * @var TestLogger */ private $logger; /** * @var SubjectUnderTest */ private $sut; protected function setUp() { $this->logger = new TestLogger(); $this->sut = new SubjectUnderTest($this->logger); } public function testLogging() { $this->sut->execute(); $log = $this->logger->log; $this->assertTrue($log->has('Message with a value')); $this->assertTrue($log->hasRecordsWithContextKey('foo')); $this->assertFalse($log->hasRecordsWithContextKeyAndValue('foo', 'unwanted')); // This will break $this->assertFalse($log->hasRecordsWithUnreplacedPlaceholders()); } }
You can find all available helper methods in the Gamez\Psr\Log\Log class. If it
doesn't provide a method you need, you can use your own filters:
use Gamez\Psr\Log\Record; use Gamez\Psr\Log\TestLogger; use PHPUnit\Framework\TestCase; class MyTest extends TestCase { /** * @var TestLogger */ private $logger; /** * @var SubjectUnderTest */ private $sut; protected function setUp() { $this->logger = new TestLogger(); $this->sut = new SubjectUnderTest($this->logger); } public function testSomethingSpecial() { $filteredLog = $this->logger->log->filter(function (Record $record) { // Matches messages with only numbers return ctype_digit($record->message); }); $this->assertCount(0, $filteredLog); } }
统计信息
- 总下载量: 194.96k
- 月度下载量: 0
- 日度下载量: 0
- 收藏数: 9
- 点击次数: 1
- 依赖项目数: 12
- 推荐数: 0
其他信息
- 授权协议: MIT
- 更新时间: 2015-08-13