Code Coverage
 
Lines
Functions and Methods
Classes and Traits
Total
87.50% covered (warning)
87.50%
7 / 8
0.00% covered (danger)
0.00%
0 / 1
CRAP
0.00% covered (danger)
0.00%
0 / 1
ItemResponseCollectionNormalizer
87.50% covered (warning)
87.50%
7 / 8
0.00% covered (danger)
0.00%
0 / 1
5.05
0.00% covered (danger)
0.00%
0 / 1
 normalize
87.50% covered (warning)
87.50%
7 / 8
0.00% covered (danger)
0.00%
0 / 1
5.05
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) 2020 (original work) Open Assessment Technologies SA
19 */
20
21declare(strict_types=1);
22
23namespace oat\taoResultServer\models\Formatter;
24
25use oat\oatbox\service\ConfigurableService;
26use stdClass;
27
28class ItemResponseCollectionNormalizer extends ConfigurableService
29{
30    /**
31     * Implementations(KV,RDS) of \taoResultServer_models_classes_ReadableResultStorage::getVariables
32     * providing a bit different structure of output, so this needed to unify before major storages refactoring happens
33     */
34    public function normalize(array $collection): array
35    {
36        $result = [];
37        foreach ($collection as $item) {
38            if (is_array($item)) {
39                foreach ($item as $i) {
40                    if ($i instanceof stdClass) {
41                        $result[] = [$i];
42                    } else {
43                        $result[] = $i;
44                    }
45                }
46            }
47        }
48        return $result;
49    }
50}