. /** * Behat step definitions for scheduled task administration. * * @package tool_task * @copyright 2017 The Open University * @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later */ // NOTE: no MOODLE_INTERNAL test here, this file may be required by behat before including /config.php. require_once(__DIR__ . '/../../../../../lib/behat/behat_base.php'); /** * Behat step definitions for scheduled task administration. * * @package tool_task * @copyright 2017 The Open University * @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later */ class behat_tool_task extends behat_base { /** * Set a fake fail delay for a scheduled task. * * @Given /^the scheduled task "(?P[^"]+)" has a fail delay of "(?P\d+)" seconds$/ * @param string $task Task classname * @param int $seconds Fail delay time in seconds */ public function scheduled_task_has_fail_delay_seconds($task, $seconds) { global $DB; $id = $DB->get_field('task_scheduled', 'id', ['classname' => $task], IGNORE_MISSING); if (!$id) { throw new Exception('Unknown scheduled task: ' . $task); } $DB->set_field('task_scheduled', 'faildelay', $seconds, ['id' => $id]); } }