Issue #57 - Calendar entry not removed on uninstall.

This commit is contained in:
Daniel Thee Roperto
2016-10-18 14:05:05 +11:00
parent fa2228697d
commit f652c9ecf0
6 changed files with 158 additions and 5 deletions

15
CHANGELOG.md Normal file
View File

@@ -0,0 +1,15 @@
# Moodle Outage manager plugin - Change Log
Version 1.0.4
-------------
* [Issue #57](https://github.com/catalyst/moodle-auth_outage/issues/57)
Calendar entries now are removed when plugin is uninstalled.
The uninstaller also makes sure there is no maintenance template or
or scheduled 'maintenance later'.
Version 1.0.3
-------------
Initial release.

View File

@@ -5,6 +5,7 @@
# Moodle Outage manager plugin
* [What is this?](#what-is-this)
* [Change Log](#change-log)
* [Moodle Requirements](#moodle-requirements)
* [Screenshots](#screenshots)
* [Installation](#installation)
@@ -25,6 +26,11 @@ an outage and after, different levels of warning and access can be provided to s
and testers letting them know what is about to happen and why.
Change Log
----------
Please see [CHANGELOG.md](CHANGELOG.md)
Moodle Requirements
-------------------

View File

@@ -96,9 +96,9 @@ class calendar {
'courseid' => 1,
'groupid' => 0,
'userid' => 0,
'modulename' => '',
'modulename' => 'auth_outage',
'instance' => $outage->id,
'eventtype' => 'auth_outage',
'eventtype' => 'outage',
'timestart' => $outage->starttime,
'visible' => true,
'timeduration' => $outage->get_duration_planned(),
@@ -115,7 +115,7 @@ class calendar {
$event = $DB->get_record_select(
'event',
"(eventtype = 'auth_outage' AND instance = :outageid)",
"(modulename='auth_outage' AND eventtype='outage' AND instance = :outageid)",
['outageid' => $outageid],
'id',
IGNORE_MISSING

46
db/uninstall.php Normal file
View File

@@ -0,0 +1,46 @@
<?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/>.
/**
* Auth Outage plugin uninstall code.
*
* @package auth_outage
* @author Daniel Thee Roperto <daniel.roperto@catalyst-au.net>
* @copyright 2016 Catalyst IT
* @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later
*/
defined('MOODLE_INTERNAL') || die();
/**
* Auth Outage plugin uninstall code.
* @return bool result
* @throws moodle_exception
*/
function xmldb_auth_outage_uninstall() {
// Delete template file.
$template = auth_outage\local\controllers\infopage::get_defaulttemplatefile();
if (file_exists($template)) {
if (!unlink($template)) {
throw new moodle_exception('Cannot remote maintenance template file: '.$template);
}
}
// Remove 'maintenance later' which could have been set for the next outage.
unset_config('maintenance_later');
return true;
}

View File

@@ -0,0 +1,86 @@
<?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/>.
/**
* installation_test test class.
*
* Tests for installs, updates and uninstalls as needed.
*
* @package auth_outage
* @author Daniel Thee Roperto <daniel.roperto@catalyst-au.net>
* @copyright 2016 Catalyst IT
* @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later
*/
use auth_outage\local\outage;
defined('MOODLE_INTERNAL') || die();
require_once(__DIR__.'/base_testcase.php');
/**
* installation_test test class.
*
* Tests for installs, updates and uninstalls as needed.
*
* @package auth_outage
* @author Daniel Thee Roperto <daniel.roperto@catalyst-au.net>
* @copyright 2016 Catalyst IT
* @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later
*/
class installation_test extends auth_outage_base_testcase {
/**
* Checks if plugin cleans up data after uninstall.
*
* See Issue #57.
*/
public function test_uninstall() {
global $CFG, $DB;
$this->resetAfterTest();
$this->setAdminUser();
$dbman = $DB->get_manager();
// Create a future outage with autostart.
$now = time();
$outage = new outage([
'autostart' => true,
'starttime' => $now + (1 * 60 * 60),
'stoptime' => $now + (2 * 60 * 60),
'warntime' => $now - (2 * 60 * 60),
'title' => 'Title',
'description' => 'Description',
]);
\auth_outage\dml\outagedb::save($outage);
self::assertSame(1, $DB->count_records_select('event', "modulename='auth_outage'", null));
// Uninstall plugin.
require_once($CFG->libdir.'/adminlib.php');
$progress = new progress_trace_buffer(new text_progress_trace(), false);
core_plugin_manager::instance()->uninstall_plugin('auth_outage', $progress);
$progress->finished();
self::assertContains('++ Success ++', $progress->get_buffer());
// Check ...
self::assertSame(0, $DB->count_records_select('event', "eventtype = 'auth_outage'", null),
'The outage events were not removed.');
self::assertFalse(file_exists(auth_outage\local\controllers\infopage::get_defaulttemplatefile()),
'The maintenance template file was not deleted.');
self::assertFalse(get_config('moodle', 'maintenance_later'),
'Maintenance later must not be set.'); // Issue #57.
self::assertFalse($dbman->table_exists('auth_outage'),
'Table "auth_outage" was not dropped.');
}
}

View File

@@ -28,7 +28,7 @@
defined('MOODLE_INTERNAL') || die();
$plugin->component = "auth_outage";
$plugin->version = 2016101400; // The current plugin version (Date: YYYYMMDDXX).
$plugin->release = '1.0.3'; // Human-readable release information.
$plugin->version = 2016101800; // The current plugin version (Date: YYYYMMDDXX).
$plugin->release = '1.0.4'; // Human-readable release information.
$plugin->requires = 2014051200; // Requires Moodle 2.7 or later. Moodle 2.9 or later recommended.
$plugin->maturity = MATURITY_STABLE; // Suitable for PRODUCTION environments!