定制 gamez/psr-testlogger 二次开发

按需修改功能、优化性能、对接业务系统,提供一站式技术支持

邮箱:yvsm@zunyunkeji.com | QQ:316430983 | 微信:yvsm316

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.

Packagist Supported PHP version Build Status GitHub license Total Downloads

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.92k
  • 月度下载量: 0
  • 日度下载量: 0
  • 收藏数: 9
  • 点击次数: 0
  • 依赖项目数: 12
  • 推荐数: 0

GitHub 信息

  • Stars: 8
  • Watchers: 1
  • Forks: 1
  • 开发语言: PHP

其他信息

  • 授权协议: MIT
  • 更新时间: 2026-01-04

承接程序开发

PHP开发

VUE

Vue开发

前端开发

小程序开发

公众号开发

系统定制

数据库设计

云部署

网站建设

安全加固