Skip to content

Commit

Permalink
MDL-64820 core: Exporter read_definition
Browse files Browse the repository at this point in the history
Modified the read_properties_definition to recursively check and set the default array values expected.
  • Loading branch information
Peter authored and ryanwyllie committed Mar 22, 2019
1 parent 3271c39 commit 432cdac
Show file tree
Hide file tree
Showing 2 changed files with 29 additions and 4 deletions.
24 changes: 20 additions & 4 deletions lib/classes/external/exporter.php
Original file line number Diff line number Diff line change
Expand Up @@ -261,16 +261,32 @@ protected function get_other_values(renderer_base $output) {
final public static function read_properties_definition() {
$properties = static::properties_definition();
$customprops = static::define_other_properties();
foreach ($customprops as $property => $definition) {
$customprops = static::format_properties($customprops);
$properties += $customprops;
return $properties;
}

/**
* Recursively formats a given property definition with the default fields required.
*
* @param array $properties List of properties to format
* @return array Formatted array
*/
final public static function format_properties($properties) {
foreach ($properties as $property => $definition) {
// Ensures that null is set to its default.
if (!isset($definition['null'])) {
$customprops[$property]['null'] = NULL_NOT_ALLOWED;
$properties[$property]['null'] = NULL_NOT_ALLOWED;
}
if (!isset($definition['description'])) {
$customprops[$property]['description'] = $property;
$properties[$property]['description'] = $property;
}

// If an array is provided, it may be a nested array that is unformatted so rinse and repeat.
if (is_array($definition['type'])) {
$properties[$property]['type'] = static::format_properties($definition['type']);
}
}
$properties += $customprops;
return $properties;
}

Expand Down
9 changes: 9 additions & 0 deletions lib/tests/exporter_test.php
Original file line number Diff line number Diff line change
Expand Up @@ -179,6 +179,8 @@ public function test_properties_description() {
$this->assertEquals('otherstring description', $properties['otherstring']['description']);
// Other properties default description.
$this->assertEquals('otherstrings', $properties['otherstrings']['description']);
// Assert nested elements are formatted correctly.
$this->assertEquals('id', $properties['nestedarray']['type']['id']['description']);
}
}

Expand Down Expand Up @@ -228,6 +230,13 @@ public static function define_other_properties() {
'otherstrings' => array(
'type' => PARAM_TEXT,
'multiple' => true
),
'nestedarray' => array(
'multiple' => true,
'optional' => true,
'type' => [
'id' => ['type' => PARAM_INT]
]
)
);
}
Expand Down

0 comments on commit 432cdac

Please sign in to comment.