Code Coverage
 
Lines
Functions and Methods
Classes and Traits
Total
100.00% covered (success)
100.00%
8 / 8
100.00% covered (success)
100.00%
2 / 2
CRAP
100.00% covered (success)
100.00%
1 / 1
LoggerObserver
100.00% covered (success)
100.00%
8 / 8
100.00% covered (success)
100.00%
2 / 2
2
100.00% covered (success)
100.00%
1 / 1
 __construct
100.00% covered (success)
100.00%
1 / 1
100.00% covered (success)
100.00%
1 / 1
1
 update
100.00% covered (success)
100.00%
7 / 7
100.00% covered (success)
100.00%
1 / 1
1
1<?php
2
3/**
4 * This program is free software; you can redistribute it and/or
5 * modify it under the terms of the GNU General Public License
6 * as published by the Free Software Foundation; under version 2
7 * of the License (non-upgradable).
8 *
9 * This program is distributed in the hope that it will be useful,
10 * but WITHOUT ANY WARRANTY; without even the implied warranty of
11 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
12 * GNU General Public License for more details.
13 *
14 * You should have received a copy of the GNU General Public License
15 * along with this program; if not, write to the Free Software
16 * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA  02110-1301, USA.
17 *
18 * Copyright (c) 2022 (original work) Open Assessment Technologies SA.
19 */
20
21declare(strict_types=1);
22
23namespace oat\tao\model\Observer\Log;
24
25use Psr\Log\LoggerInterface;
26use SplObserver;
27use SplSubject;
28
29class LoggerObserver implements SplObserver
30{
31    /** @var LoggerInterface */
32    private $logger;
33
34    public function __construct(LoggerInterface $logger)
35    {
36        $this->logger = $logger;
37    }
38
39    /**
40     * @inheritDoc
41     */
42    public function update(SplSubject $subject): void
43    {
44        $this->logger->info(
45            sprintf(
46                'Observer updated with subject "%s" and data %s',
47                get_class($subject),
48                substr((string)json_encode($subject), 0, 250) . '...'
49            )
50        );
51    }
52}