1<?php
2// This file is part of Moodle - http://moodle.org/
3//
4// Moodle is free software: you can redistribute it and/or modify
5// it under the terms of the GNU General Public License as published by
6// the Free Software Foundation, either version 3 of the License, or
7// (at your option) any later version.
8//
9// Moodle is distributed in the hope that it will be useful,
10// but WITHOUT ANY WARRANTY; without even the implied warranty of
11// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
12// GNU General Public License for more details.
13//
14// You should have received a copy of the GNU General Public License
15// along with Moodle.  If not, see <http://www.gnu.org/licenses/>.
16
17/**
18 * PHPUnit data generator tests.
19 *
20 * @package mod_resource
21 * @category phpunit
22 * @copyright 2013 The Open University
23 * @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later
24 */
25
26defined('MOODLE_INTERNAL') || die();
27
28
29/**
30 * PHPUnit data generator testcase.
31 *
32 * @package    mod_resource
33 * @category phpunit
34 * @copyright 2013 The Open University
35 * @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later
36 */
37class mod_resource_generator_testcase extends advanced_testcase {
38    public function test_generator() {
39        global $DB, $SITE;
40
41        $this->resetAfterTest(true);
42
43        // Must be a non-guest user to create resources.
44        $this->setAdminUser();
45
46        // There are 0 resources initially.
47        $this->assertEquals(0, $DB->count_records('resource'));
48
49        // Create the generator object and do standard checks.
50        $generator = $this->getDataGenerator()->get_plugin_generator('mod_resource');
51        $this->assertInstanceOf('mod_resource_generator', $generator);
52        $this->assertEquals('resource', $generator->get_modulename());
53
54        // Create three instances in the site course.
55        $generator->create_instance(array('course' => $SITE->id));
56        $generator->create_instance(array('course' => $SITE->id));
57        $resource = $generator->create_instance(array('course' => $SITE->id));
58        $this->assertEquals(3, $DB->count_records('resource'));
59
60        // Check the course-module is correct.
61        $cm = get_coursemodule_from_instance('resource', $resource->id);
62        $this->assertEquals($resource->id, $cm->instance);
63        $this->assertEquals('resource', $cm->modname);
64        $this->assertEquals($SITE->id, $cm->course);
65
66        // Check the context is correct.
67        $context = context_module::instance($cm->id);
68        $this->assertEquals($resource->cmid, $context->instanceid);
69
70        // Check that generated resource module contains a file.
71        $fs = get_file_storage();
72        $files = $fs->get_area_files($context->id, 'mod_resource', 'content', false, '', false);
73        $this->assertEquals(1, count($files));
74    }
75}
76