PHPUnit 接收系统日志消息?

Posted

技术标签:

【中文标题】PHPUnit 接收系统日志消息?【英文标题】:PHPUnit picking up on syslog messages? 【发布时间】:2016-12-15 12:08:05 【问题描述】:

我正在测试一个记录器类,其方法可以像这样打开日志:

openlog($this->identifier, $this->option, $this->facility);
syslog($level, $message)
closelog();

我的记录器写入的$facility 当前设置为LOCAL0

当我对我的记录器进行单元测试时,我收到以下消息:

Broadcast message from systemd-journald@myWS:

phpserver7.0[9125]: Logger message  

如何使用 PHPUnit 或在我的代码中隐藏此消息?

编辑:

这似乎只发生在我记录严重级别为“紧急”的消息时,即严重级别为 0。

https://en.wikipedia.org/wiki/Syslog#Severity_level

***指出:

应用程序不应使用此级别。

尽管如此,它仍然是 PSR-3 记录器摘要的一部分,所以我希望能够使用 PHPUnit 抑制消息。

【问题讨论】:

【参考方案1】:

在您的测试方法中,您可以通过在产生输出的调用周围包裹一个输出缓冲区来抑制输出。示例:

/**
 * @preserveGlobalState disabled
 * @runInSeparateProcess
 */
public function testOutputCanSend()

    ob_start();

    // Do some stuff here that outputs directly, e.g
    openlog($this->identifier, $this->option, $this->facility);
    syslog($level, $message)
    closelog();

    ob_end_clean();

【讨论】:

以上是关于PHPUnit 接收系统日志消息?的主要内容,如果未能解决你的问题,请参考以下文章

如何接收系统日志消息并将其转换为字符串

如何充当系统日志接收器?

syslog介绍-CS架构来采集系统日志

询问流利的系统日志聚合器

syslog相关内容介绍

RabbitMQ 发布/订阅