Proyectos de Subversion Moodle

Rev

Rev 1 | | Comparar con el anterior | Ultima modificación | Ver Log |

Rev Autor Línea Nro. Línea
1 efrain 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
namespace core_search\external;
18
 
19
use core_external\external_api;
20
 
21
defined('MOODLE_INTERNAL') || die();
22
 
23
global $CFG;
24
require_once($CFG->dirroot . '/webservice/tests/helpers.php');
25
 
26
/**
27
 * Tests for the get_results external function.
28
 *
29
 * @package    core_search
30
 * @category   test
31
 * @copyright  2023 Juan Leyva (juan@moodle.com)
32
 * @license    http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later
33
 * @coversDefaultClass \core_search\external\get_results
34
 */
1441 ariadna 35
final class get_results_test extends \externallib_advanced_testcase {
1 efrain 36
 
37
    public function setUp(): void {
1441 ariadna 38
        parent::setUp();
1 efrain 39
        $this->resetAfterTest();
40
    }
41
 
42
    /**
43
     * test external api
44
     * @covers ::execute
45
     * @return void
46
     */
47
    public function test_external_get_results(): void {
48
 
49
        set_config('enableglobalsearch', true);
50
        set_config('searchengine', 'simpledb');
51
 
52
        $this->setAdminUser();
53
 
54
        // Test search not returning anything (nothing in the index yet).
55
        $return = external_api::clean_returnvalue(get_results::execute_returns(), get_results::execute('one'));
56
        $this->assertEquals(0, $return['totalcount']);
57
 
58
        // Create an index of searchable things.
59
        $generator = $this->getDataGenerator();
60
        $course = $generator->create_course(['fullname' => 'SearchTest course']);
61
        $anothercourse = $generator->create_course(['fullname' => 'Another']);
62
        $student = $this->getDataGenerator()->create_and_enrol($course, 'student');
63
        $studentothercourse = $this->getDataGenerator()->create_and_enrol($anothercourse, 'student');
64
        $page = $generator->create_module('page', ['course' => $course->id, 'name' => 'SearchTest page']);
65
        $forum = $generator->create_module('forum', ['course' => $course->id]);
66
 
67
        $fgenerator = $generator->get_plugin_generator('mod_forum');
68
 
69
        for ($i = 0; $i < 15; $i++) {
70
            $fgenerator->create_discussion(
71
                [
72
                    'course' => $course->id,
73
                    'forum' => $forum->id,
74
                    'userid' => $student->id,
75
                ]
76
            );
77
        }
78
 
79
        $search = \core_search\manager::instance();
80
        $search->index();
81
 
82
        // Basic search, by text.
83
        $return = external_api::clean_returnvalue(get_results::execute_returns(), get_results::execute('page'));
84
        $this->assertEquals(1, $return['totalcount']);
85
        $this->assertEquals('activity', $return['results'][0]['areaname']);
86
        $this->assertEquals($page->name, $return['results'][0]['title']);
87
 
88
        // Basic search, by name containing text.
89
        $return = external_api::clean_returnvalue(get_results::execute_returns(), get_results::execute('SearchTest'));
90
        $this->assertEquals(2, $return['totalcount']);
91
 
92
        // Test pagination.
93
        $return = external_api::clean_returnvalue(get_results::execute_returns(), get_results::execute('discussion', [], 0));
94
        $this->assertCount(10, $return['results']);  // The first 10 posts of a total of 15 for the second page.
95
        $this->assertEquals(15, $return['totalcount']);
96
 
97
        $return = external_api::clean_returnvalue(get_results::execute_returns(), get_results::execute('discussion', [], 1));
98
        $this->assertCount(5, $return['results']);  // The last 5 posts of a total of 15 for the second page.
99
        $this->assertEquals(15, $return['totalcount']);
100
 
101
        // Test some filters.
102
        $return = external_api::clean_returnvalue(get_results::execute_returns(),
103
            get_results::execute('discussion', ['title' => 'Discussion 11']));
104
        $this->assertEquals(1, $return['totalcount']);
105
 
106
        // No discussions created in the future.
107
        $return = external_api::clean_returnvalue(get_results::execute_returns(),
108
            get_results::execute('discussion', ['timestart' => time() + DAYSECS]));
109
        $this->assertEquals(0, $return['totalcount']);
110
 
111
        // Basic permissions check.
112
        $this->setUser($studentothercourse);
113
        $return = external_api::clean_returnvalue(get_results::execute_returns(), get_results::execute('discussion', [], 1));
114
        $this->assertCount(0, $return['results']);  // I should not see other courses discussions.
115
    }
116
}