tao-test/app/taoQtiTest/models/classes/runner/map/TestMapBranchRuleExtender.php

103 lines
3.8 KiB
PHP

<?php
/**
* This program is free software; you can redistribute it and/or
* modify it under the terms of the GNU General Public License
* as published by the Free Software Foundation; under version 2
* of the License (non-upgradable).
*
* This program is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU General Public License for more details.
*
* You should have received a copy of the GNU General Public License
* along with this program; if not, write to the Free Software
* Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
*
* Copyright (c) 2019 (original work) Open Assessment Technologies SA ;
*/
/**
* @author Péter Halász <peter@taotesting.com>
*/
namespace oat\taoQtiTest\models\runner\map;
use taoQtiTest_models_classes_QtiTestService;
class TestMapBranchRuleExtender
{
const KEY_ATTRIBUTES = '@attributes';
const KEY_BRANCH_RULE = 'branchRule';
const KEY_IDENTIFIER = 'identifier';
const BRANCH_RULE_MAP_PAIRS = [
[RunnerMap::MAP_ATTRIBUTE_PARTS, taoQtiTest_models_classes_QtiTestService::XML_TEST_PART],
[RunnerMap::MAP_ATTRIBUTE_SECTIONS, taoQtiTest_models_classes_QtiTestService::XML_ASSESSMENT_SECTION],
[RunnerMap::MAP_ATTRIBUTE_ITEMS, taoQtiTest_models_classes_QtiTestService::XML_ASSESSMENT_ITEM_REF],
];
/**
* Returns the testMap, extended with the branch rules from the testDefinition
*
* @param array $testMap
* @param array $testDefinition
* @return array
*/
public function getTestMapWithBranchRules(array $testMap, array $testDefinition)
{
return $this->addBranchRuleToTestMapRecursively($testMap, $testDefinition, self::BRANCH_RULE_MAP_PAIRS);
}
/**
* Adds the branching rules from the given testDefinition into the testMap, going through recursively on the given mapping pairs.
*
* @param array $testMap
* @param array $testDefinition
* @param array $map
* @return array
*/
private function addBranchRuleToTestMapRecursively($testMap, $testDefinition, $map)
{
list ($testMapIdentifier, $testDefinitionIdentifier) = array_shift($map);
foreach ($testMap[$testMapIdentifier] as $id => $testMapSubObject) {
foreach ($testDefinition[$testDefinitionIdentifier] as $testDefinitionSubObject) {
if ($testDefinitionSubObject[self::KEY_ATTRIBUTES][self::KEY_IDENTIFIER] === $id) {
if (count($map) > 0) {
$testMap[$testMapIdentifier][$id] = $this->addBranchRuleToTestMapRecursively(
$testMapSubObject,
$testDefinitionSubObject,
$map
);
}
$testMap = $this->addBranchRuleToTestMap($testMap, $testDefinitionSubObject, $testMapIdentifier, $id);
}
}
}
return $testMap;
}
/**
* Adds the branch rule to the testMap if there is branching rule for the given testDefinitionSubObject.
* If there is no branch rule, it adds an empty object instead.
*
* @param array $testMap
* @param array $testDefinitionSubObject
* @param string $testMapIdentifier
* @param string $id
* @return array
*/
private function addBranchRuleToTestMap($testMap, $testDefinitionSubObject, $testMapIdentifier, $id)
{
$testMap[$testMapIdentifier][$id][self::KEY_BRANCH_RULE] =
array_key_exists(self::KEY_BRANCH_RULE, $testDefinitionSubObject)
? $testDefinitionSubObject[self::KEY_BRANCH_RULE]
: new \stdClass();
return $testMap;
}
}