~ubuntu-branches/ubuntu/utopic/moodle/utopic

« back to all changes in this revision

Viewing changes to mod/folder/tests/generator_test.php

  • Committer: Package Import Robot
  • Author(s): Thijs Kinkhorst
  • Date: 2014-05-12 16:10:38 UTC
  • mfrom: (36.1.3 sid)
  • Revision ID: package-import@ubuntu.com-20140512161038-puyqf65k4e0s8ytz
Tags: 2.6.3-1
New upstream release.

Show diffs side-by-side

added added

removed removed

Lines of Context:
 
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
 * mod_folder generator tests
 
19
 *
 
20
 * @package    mod_folder
 
21
 * @category   test
 
22
 * @copyright  2013 Marina Glancy
 
23
 * @license    http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later
 
24
 */
 
25
 
 
26
/**
 
27
 * Genarator tests class for mod_folder.
 
28
 *
 
29
 * @package    mod_folder
 
30
 * @category   test
 
31
 * @copyright  2013 Marina Glancy
 
32
 * @license    http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later
 
33
 */
 
34
class mod_folder_generator_testcase extends advanced_testcase {
 
35
 
 
36
    public function test_create_instance() {
 
37
        global $DB, $USER;
 
38
        $this->resetAfterTest();
 
39
        $this->setAdminUser();
 
40
 
 
41
        $course = $this->getDataGenerator()->create_course();
 
42
 
 
43
        $this->assertFalse($DB->record_exists('folder', array('course' => $course->id)));
 
44
        $folder = $this->getDataGenerator()->create_module('folder', array('course' => $course));
 
45
        $records = $DB->get_records('folder', array('course' => $course->id), 'id');
 
46
        $this->assertEquals(1, count($records));
 
47
        $this->assertTrue(array_key_exists($folder->id, $records));
 
48
 
 
49
        $params = array('course' => $course->id, 'name' => 'Another folder');
 
50
        $folder = $this->getDataGenerator()->create_module('folder', $params);
 
51
        $records = $DB->get_records('folder', array('course' => $course->id), 'id');
 
52
        $this->assertEquals(2, count($records));
 
53
        $this->assertEquals('Another folder', $records[$folder->id]->name);
 
54
 
 
55
        // Examples of adding a folder with files (do not validate anything, just check for exceptions).
 
56
        $params = array(
 
57
            'course' => $course->id,
 
58
            'files' => file_get_unused_draft_itemid()
 
59
        );
 
60
        $usercontext = context_user::instance($USER->id);
 
61
        $filerecord = array('component' => 'user', 'filearea' => 'draft',
 
62
                'contextid' => $usercontext->id, 'itemid' => $params['files'],
 
63
                'filename' => 'file1.txt', 'filepath' => '/');
 
64
        $fs = get_file_storage();
 
65
        $fs->create_file_from_string($filerecord, 'Test file contents');
 
66
        $folder = $this->getDataGenerator()->create_module('folder', $params);
 
67
    }
 
68
}