Code Coverage
 
Lines
Functions and Methods
Classes and Traits
Total
100.00% covered (success)
100.00%
17 / 17
100.00% covered (success)
100.00%
2 / 2
CRAP
100.00% covered (success)
100.00%
1 / 1
TranslationSyncService
100.00% covered (success)
100.00%
17 / 17
100.00% covered (success)
100.00%
2 / 2
3
100.00% covered (success)
100.00%
1 / 1
 __construct
100.00% covered (success)
100.00%
2 / 2
100.00% covered (success)
100.00%
1 / 1
1
 __invoke
100.00% covered (success)
100.00%
15 / 15
100.00% covered (success)
100.00%
1 / 1
2
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) 2024 (original work) Open Assessment Technologies SA.
19 */
20
21declare(strict_types=1);
22
23namespace oat\taoQtiTest\models\Translation\Service;
24
25use core_kernel_classes_Resource;
26use oat\tao\model\Translation\Exception\ResourceTranslationException;
27use Psr\Log\LoggerInterface;
28use Throwable;
29
30class TranslationSyncService
31{
32    private TestTranslator $testTranslator;
33    private LoggerInterface $logger;
34
35    public function __construct(TestTranslator $testTranslator, LoggerInterface $logger)
36    {
37        $this->testTranslator = $testTranslator;
38        $this->logger = $logger;
39    }
40
41    public function __invoke(core_kernel_classes_Resource $test): core_kernel_classes_Resource
42    {
43        try {
44            return $this->testTranslator->translate($test);
45        } catch (Throwable $exception) {
46            $message = sprintf(
47                'An error occurred while trying to synchronize the translation for test %s.',
48                $test->getUri()
49            );
50
51            $this->logger->error(
52                sprintf(
53                    '%s. Error: (%s) %s',
54                    $message,
55                    get_class($exception),
56                    $exception->getMessage()
57                )
58            );
59
60            throw new ResourceTranslationException($message);
61        }
62    }
63}