AutorÃa | Ultima modificación | Ver Log |
<?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/>.
/**
* Basic unit tests for the coursecompleted condition.
*
* @package availability_coursecompleted
* @copyright 2017 iplusacademy (www.iplusacademy.org)
* @author Renaat Debleu <info@eWallah.net>
* @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later
*/
namespace availability_coursecompleted;
use availability_coursecompleted\{condition, frontend};
use completion_info;
use core_availability\{tree, info_module, mock_info, mock_condition};
use core_completion;
/**
* Bare tests for the coursecompleted condition.
*
* @package availability_coursecompleted
* @copyright 2017 iplusacademy (www.iplusacademy.org)
* @author Renaat Debleu <info@eWallah.net>
* @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later
* @coversDefaultClass \availability_coursecompleted
*/
final class basic_test extends \basic_testcase {
/**
* Tests the constructor including error conditions.
* @covers \availability_coursecompleted\condition
*/
public function test_constructor(): void {
// This works with no parameters.
$structure = (object)[];
try {
$completed = new condition($structure);
$this->fail();
} catch (\exception $e) {
$this->assertEquals('', $e->getMessage());
}
$this->assertNotEmpty($completed);
// This works with '1'.
$structure->id = '1';
try {
$completed = new condition($structure);
$this->fail();
} catch (\exception $e) {
$this->assertEquals('', $e->getMessage());
}
$this->assertNotEmpty($completed);
// This works with '0'.
$structure->id = '0';
try {
$completed = new condition($structure);
$this->fail();
} catch (\exception $e) {
$this->assertEquals('', $e->getMessage());
}
$this->assertNotEmpty($completed);
// This fails with null.
$structure->id = null;
try {
$completed = new condition($structure);
} catch (\coding_exception $e) {
$this->assertStringContainsString('Invalid value for course completed condition', $e->getMessage());
}
// Invalid ->id.
$structure->id = false;
try {
$completed = new condition($structure);
} catch (\coding_exception $e) {
$this->assertStringContainsString('Invalid value for course completed condition', $e->getMessage());
}
// Invalid string. Should be checked 'longer string'.
$structure->id = 1;
try {
$completed = new condition($structure);
} catch (\coding_exception $e) {
$this->assertStringContainsString('Invalid value for course completed condition', $e->getMessage());
}
}
/**
* Tests the save() function.
* @covers \availability_coursecompleted\condition
*/
public function test_save(): void {
$structure = (object)['id' => '1'];
$cond = new condition($structure);
$structure->type = 'coursecompleted';
$this->assertEquals($structure, $cond->save());
}
/**
* Tests json.
* @covers \availability_coursecompleted\condition
*/
public function test_json(): void {
$this->assertEqualsCanonicalizing((object)['type' => 'coursecompleted', 'id' => '3'], condition::get_json('3'));
$this->assertEqualsCanonicalizing((object)['type' => 'coursecompleted', 'id' => '0'], condition::get_json('0'));
}
}