mirror of
https://github.com/moodle/moodle.git
synced 2025-02-26 13:03:53 +01:00
Before this patch the exported users (to csv file that jmeter consumes) were all the enrolled users in the test course. And that's ok when the number of users enrolled match the number of concurrent threads planned for a jmeter plan (each thread is a user). But when both numbers don't match, that can lead to the jmeter plan not behaving as expected, because it iterates over the excessive users in the file, leading to some users having run 5 loops, others 4... The only way to make results more consistent is to, always, ensure that the number of users exported for the plan match the plan size and not the site size. And that's what this issue exactly does, restrict the export to the number of threads that the plan will have. So every user always runs the very same number of loops.
88 lines
3.0 KiB
PHP
88 lines
3.0 KiB
PHP
<?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/>.
|
|
|
|
/**
|
|
* Generates a JMeter test plan to performance comparison.
|
|
*
|
|
* @package tool_generator
|
|
* @copyright 2013 David Monllaó
|
|
* @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later
|
|
*/
|
|
|
|
require(__DIR__ . '/../../../config.php');
|
|
require_once($CFG->libdir . '/adminlib.php');
|
|
|
|
// Initialise page and check permissions.
|
|
admin_externalpage_setup('toolgeneratortestplan');
|
|
|
|
// Start page.
|
|
echo $OUTPUT->header();
|
|
echo $OUTPUT->heading(get_string('maketestplan', 'tool_generator'));
|
|
|
|
// Information message.
|
|
$context = context_system::instance();
|
|
$markdownlink = '[' . tool_generator_testplan_backend::get_repourl() . '](' . tool_generator_testplan_backend::get_repourl() . ')';
|
|
echo $OUTPUT->box(format_text(get_string('testplanexplanation', 'tool_generator', $markdownlink),
|
|
FORMAT_MARKDOWN, array('context' => $context)));
|
|
|
|
// Check debugging is set to DEVELOPER.
|
|
if (!$CFG->debugdeveloper) {
|
|
echo $OUTPUT->notification(get_string('error_notdebugging', 'tool_generator'));
|
|
echo $OUTPUT->footer();
|
|
exit;
|
|
}
|
|
|
|
// Set up the form.
|
|
$mform = new tool_generator_make_testplan_form('maketestplan.php');
|
|
if ($data = $mform->get_data()) {
|
|
|
|
// Creating both test plan and users files.
|
|
$testplanfile = tool_generator_testplan_backend::create_testplan_file($data->courseid, $data->size);
|
|
$usersfile = tool_generator_testplan_backend::create_users_file($data->courseid, $data->updateuserspassword, $data->size);
|
|
|
|
// Test plan link.
|
|
$testplanurl = moodle_url::make_pluginfile_url(
|
|
$testplanfile->get_contextid(),
|
|
$testplanfile->get_component(),
|
|
$testplanfile->get_filearea(),
|
|
$testplanfile->get_itemid(),
|
|
$testplanfile->get_filepath(),
|
|
$testplanfile->get_filename()
|
|
);
|
|
echo html_writer::div(
|
|
html_writer::link($testplanurl, get_string('downloadtestplan', 'tool_generator'))
|
|
);
|
|
|
|
// Users file link.
|
|
$usersfileurl = moodle_url::make_pluginfile_url(
|
|
$usersfile->get_contextid(),
|
|
$usersfile->get_component(),
|
|
$usersfile->get_filearea(),
|
|
$usersfile->get_itemid(),
|
|
$usersfile->get_filepath(),
|
|
$usersfile->get_filename()
|
|
);
|
|
echo html_writer::div(
|
|
html_writer::link($usersfileurl, get_string('downloadusersfile', 'tool_generator'))
|
|
);
|
|
|
|
} else {
|
|
// Display form.
|
|
$mform->display();
|
|
}
|
|
|
|
echo $OUTPUT->footer();
|