mirror of
https://github.com/moodle/moodle.git
synced 2025-01-19 14:27:22 +01:00
caf55abf17
Applied the following changes to various testcase classes: - Namespaced with component[\level2-API] - Moved to level2-API subdirectory when required. - Fixed incorrect use statements with leading backslash. - Remove file phpdoc block - Remove MOODLE_INTERNAL if not needed. - Changed code to point to global scope when needed. - Fix some relative paths and comments here and there. - All them passing individually. - Complete runs passing too. Special mention to: - Moved to the level2 "privacy" namespace: - \mod_assign\privacy\feedback_legacy_polyfill_test - \mod_assign\privacy\submission_legacy_polyfill_test - Moved to the level2 "task" namespace: - \core_message\task\migrate_message_data_test - \ltiservice_gradebookservices\task\cleanup_test - \message_email\task\send_email_test - \mod_lti\task\clean_access_tokens_test - \mod_workshop\task\cron_task_test - Moved to the level2 "event" namespace: - \core_h5p\event\deleted_test - \core_h5p\event\viewed_test - Renamed to a better name: - backup_forum_activity_task_test.php (missing "task")
161 lines
5.0 KiB
PHP
161 lines
5.0 KiB
PHP
<?php
|
|
// This file is part of Moodle - http://moodle.org/
|
|
//
|
|
// Moodle 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, either version 3 of the License, or
|
|
// (at your option) any later version.
|
|
//
|
|
// Moodle 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 Moodle. If not, see <http://www.gnu.org/licenses/>.
|
|
|
|
namespace mod_lesson;
|
|
|
|
use mod_lesson\local\numeric\helper;
|
|
|
|
/**
|
|
* This class contains the test cases for the numeric helper functions
|
|
*
|
|
* @package mod_lesson
|
|
* @category test
|
|
* @copyright 2020 Peter Dias
|
|
* @license http://www.gnu.org/copyleft/gpl.html GNU Public License
|
|
*/
|
|
class numeric_helper_test extends \advanced_testcase {
|
|
/**
|
|
* Test the lesson_unformat_numeric_value function.
|
|
*
|
|
* @dataProvider lesson_unformat_dataprovider
|
|
* @param $decsep
|
|
* @param $tests
|
|
*/
|
|
public function test_lesson_unformat_numeric_value($decsep, $tests) {
|
|
$this->define_local_decimal_separator($decsep);
|
|
|
|
foreach ($tests as $test) {
|
|
$this->assertEquals($test[1], helper::lesson_unformat_numeric_value($test[0]));
|
|
}
|
|
}
|
|
|
|
/**
|
|
* Test the lesson_format_numeric_value function.
|
|
*
|
|
* @dataProvider lesson_format_dataprovider
|
|
* @param $decsep
|
|
* @param $tests
|
|
*/
|
|
public function test_lesson_format_numeric_value($decsep, $tests) {
|
|
$this->define_local_decimal_separator($decsep);
|
|
|
|
foreach ($tests as $test) {
|
|
$this->assertEquals($test[1], helper::lesson_format_numeric_value($test[0]));
|
|
}
|
|
}
|
|
|
|
/**
|
|
* Provide various cases for the unformat test function
|
|
*
|
|
* @return array
|
|
*/
|
|
public function lesson_unformat_dataprovider() {
|
|
return [
|
|
"Using a decimal as a separator" => [
|
|
"decsep" => ".",
|
|
"test" => [
|
|
["2.1", 2.1],
|
|
["1:4.2", "1:4.2"],
|
|
["2,1", 2],
|
|
["1:4,2", "1:4"],
|
|
["", null]
|
|
]
|
|
],
|
|
"Using a comma as a separator" => [
|
|
"decsep" => ",",
|
|
"test" => [
|
|
["2,1", 2.1],
|
|
["1:4,2", "1:4.2"],
|
|
["2.1", 2.1],
|
|
["1:4.2", "1:4.2"],
|
|
]
|
|
],
|
|
"Using a X as a separator" => [
|
|
"decsep" => "X",
|
|
"test" => [
|
|
["2X1", 2.1],
|
|
["1:4X2", "1:4.2"],
|
|
["2.1", 2.1],
|
|
["1:4.2", "1:4.2"],
|
|
]
|
|
]
|
|
];
|
|
}
|
|
|
|
/**
|
|
* Provide various cases for the unformat test function
|
|
*
|
|
* @return array
|
|
*/
|
|
public function lesson_format_dataprovider() {
|
|
return [
|
|
"Using a decimal as a separator" => [
|
|
"decsep" => ".",
|
|
"test" => [
|
|
["2.1", 2.1],
|
|
["1:4.2", "1:4.2"],
|
|
["2,1", "2,1"],
|
|
["1:4,2", "1:4,2"]
|
|
]
|
|
],
|
|
"Using a comma as a separator" => [
|
|
"decsep" => ",",
|
|
"test" => [
|
|
["2,1", "2,1"],
|
|
["1:4,2", "1:4,2"],
|
|
["2.1", "2,1"],
|
|
[2.1, "2,1"],
|
|
["1:4.2", "1:4,2"],
|
|
]
|
|
],
|
|
"Using a X as a separator" => [
|
|
"decsep" => "X",
|
|
"test" => [
|
|
["2X1", "2X1"],
|
|
["1:4X2", "1:4X2"],
|
|
["2.1", "2X1"],
|
|
["1:4.2", "1:4X2"],
|
|
]
|
|
]
|
|
];
|
|
}
|
|
|
|
|
|
/**
|
|
* Define a local decimal separator.
|
|
*
|
|
* It is not possible to directly change the result of get_string in
|
|
* a unit test. Instead, we create a language pack for language 'xx' in
|
|
* dataroot and make langconfig.php with the string we need to change.
|
|
* The default example separator used here is 'X'.
|
|
*
|
|
* @param string $decsep Separator character. Defaults to `'X'`.
|
|
*/
|
|
protected function define_local_decimal_separator(string $decsep = 'X') {
|
|
global $SESSION, $CFG;
|
|
|
|
$SESSION->lang = 'xx';
|
|
$langconfig = "<?php\n\$string['decsep'] = '$decsep';";
|
|
$langfolder = $CFG->dataroot . '/lang/xx';
|
|
check_dir_exists($langfolder);
|
|
file_put_contents($langfolder . '/langconfig.php', $langconfig);
|
|
|
|
// Ensure the new value is picked up and not taken from the cache.
|
|
$stringmanager = get_string_manager();
|
|
$stringmanager->reset_caches(true);
|
|
}
|
|
}
|