服务定义“monolog.logger.event”不存在

时间:2016-04-17 22:44:01

标签: symfony monolog

我为我的monolog创建了不同的通道,在使用我的应用程序(开发和测试环境)时,一切都很好,创建并写入所有日志,但是当执行我的测试(单元测试)时,我收到以下错误:“服务定义“monolog.logger.event”不存在“ 我将“ContainerBuilder $ container”转储到“vendor / symfony / monolog-bundle / DependencyInjection / Compiler / LoggerChannelPass.php”中,由于某种原因,monolog.logger.event不存在,其余所有通道都存在:学说,要求,安全等...... 我正在粘贴与频道对应的monolog配置:

monolog:
    handlers:
        main:
            type:   stream
            path:   "%kernel.logs_dir%/%kernel.environment%.log"
            level:  debug
            channels: ['!event', '!snc_redis', '!doctrine', '!request', '!security']
        event:
            type:   stream
            path:   "%kernel.logs_dir%/%kernel.environment%_event.log"
            level:  debug
            channels: ['event']
        snc_redis:
            type:   stream
            path:   "%kernel.logs_dir%/%kernel.environment%_redis.log"
            level:  debug
            channels: ['snc_redis']
        doctrine:
            type:  stream
            path:   "%kernel.logs_dir%/%kernel.environment%_doctrine.log"
            level:  debug
            channels: ['doctrine']
        request:
            type:  stream
            path:   "%kernel.logs_dir%/%kernel.environment%_request.log"
            level:  debug
            channels: ['request']
        security:
            type:  stream
            path:   "%kernel.logs_dir%/%kernel.environment%_security.log"
            level:  debug
            channels: ['security']

任何线索如何解决这个问题

1 个答案:

答案 0 :(得分:0)

这是因为 web / app_test.php 和控制台有不同的调试标志,例如:

#web/app_test.php    
$kernel = new AppKernel('test', false);

#bin(app)/console
$kernel = new AppKernel('test', true);

在这种情况下,Web应用程序找不到正确的缓存容器文件。