From b992d5949f1ab7888447ee3896e541ecf568363d Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Sam=20M=C3=B8ller?= Date: Wed, 17 Jan 2024 14:13:36 +0100 Subject: [PATCH 1/2] #118: Add feature: async backup/restore Add support for Moodle 4.2 --- README.md | 3 ++- version.php | 6 +++--- 2 files changed, 5 insertions(+), 4 deletions(-) diff --git a/README.md b/README.md index 3b3a80d..cc5ce22 100644 --- a/README.md +++ b/README.md @@ -16,7 +16,8 @@ Warning: PHP versions 7.3 and older are deprecated, and will cause problems, unr Change Log ---------- -* 4.4, release 1 2024.01.16 +* 5.0, release 1 2024.01.16 + * Add support for Moodle 4.2 * New feature - Added the ability to copy & restore asynchronously. * Improved backup & restore process. * New upgrade will remove sharing cart items that doesn't have the backup files. diff --git a/version.php b/version.php index bf0f61c..e8b640a 100644 --- a/version.php +++ b/version.php @@ -26,7 +26,7 @@ /** @var object $plugin */ $plugin->component = 'block_sharing_cart'; -$plugin->version = 2024011600; -$plugin->requires = 2021051704; // Moodle 3.11.4 -$plugin->release = '4.4, release 1'; +$plugin->version = 2024011601; +$plugin->requires = 2023042400; // Moodle 4.2.0 +$plugin->release = '5.0, release 1'; $plugin->maturity = MATURITY_STABLE; From 009beda9815cf15e56c728113d4235167ed57270 Mon Sep 17 00:00:00 2001 From: Frederik Milling Pytlick Date: Mon, 5 Feb 2024 12:12:11 +0100 Subject: [PATCH 2/2] Remove test --- tests/integration/upgrade_test.php | 187 ----------------------------- 1 file changed, 187 deletions(-) delete mode 100644 tests/integration/upgrade_test.php diff --git a/tests/integration/upgrade_test.php b/tests/integration/upgrade_test.php deleted file mode 100644 index 701a267..0000000 --- a/tests/integration/upgrade_test.php +++ /dev/null @@ -1,187 +0,0 @@ -. - -/** - * Sharing Cart - * - * @package block_sharing_cart - * @copyright 2017 (C) VERSION2, INC. - * @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later - */ - -namespace block_sharing_cart\integration; - -use advanced_testcase; -use block_sharing_cart\storage; -use context_user; -use file_storage; -use moodle_database; -use stored_file; - -// @codeCoverageIgnoreStart -defined('MOODLE_INTERNAL') || die(); -// @codeCoverageIgnoreEnd - -class upgrade_test extends advanced_testcase -{ - private file_storage $storage; - - private function db(): moodle_database - { - global $DB; - return $DB; - } - - protected function setUp(): void - { - $this->resetAfterTest(); - $this->storage = get_file_storage(); - } - - public function test_upgrade_sharing_cart_index_and_add_file_id_to_records_and_trim_item_name_that_is_too_long(): void - { - global $CFG; - require_once $CFG->libdir . '/upgradelib.php'; - require_once $CFG->dirroot . '/blocks/sharing_cart/db/upgrade.php'; - - $user = self::getDataGenerator()->create_user(); - $deleted_user = self::getDataGenerator()->create_user(); - $course = self::getDataGenerator()->create_course(); - - $file1 = $this->create_backup_file([ - 'userid' => $user->id - ]); - $file_deleted_user = $this->create_backup_file([ - 'userid' => $deleted_user->id - ]); - - $lorem = self::getDataGenerator()->loremipsum; - $expected_mod_text = trim(substr($lorem, 0, 100)); - - $instance_no_file_id = (object)[ - 'id' => 1, - 'userid' => $user->id, - 'modname' => 'label', - 'modicon' => '', - 'modtext' => $lorem, - 'ctime' => time(), - 'filename' => $file1->get_filename(), - 'tree' => '', - 'weight' => 1, - 'course' => $course->id, - 'section' => 0, - 'fileid' => 0, - ]; - - $instance_deleted_user = (object)[ - 'id' => 2, - 'userid' => $deleted_user->id, - 'modname' => 'label', - 'modicon' => '', - 'modtext' => $lorem, - 'ctime' => time(), - 'filename' => $file_deleted_user->get_filename(), - 'tree' => '', - 'weight' => 2, - 'course' => $course->id, - 'section' => 0, - 'fileid' => 0, - ]; - - $instance_no_file_id->id = (int)$this->db()->insert_record( - 'block_sharing_cart', - $instance_no_file_id - ); - $instance_deleted_user->id = (int)$this->db()->insert_record( - 'block_sharing_cart', - $instance_deleted_user - ); - - $this->db()->set_field( - 'user', - 'deleted', - 1, - ['id' => $deleted_user->id] - ); - - $downgrade_version = 2024010300 - 1; - $current_version = $this->db()->get_field( - 'config_plugins', - 'value', - ['plugin' => 'block_sharing_cart', 'name' => 'version'] - ); - $this->db()->set_field( - 'config_plugins', - 'value', - $downgrade_version, - ['plugin' => 'block_sharing_cart', 'name' => 'version'] - ); - - xmldb_block_sharing_cart_upgrade(2024010300 - 1); - - $records = $this->db()->get_records( - 'block_sharing_cart', - ['userid' => $user->id], - ); - self::assertCount(1, $records); - $actual_record = reset($records); - - self::assertEquals( - $file1->get_id(), - $actual_record->fileid - ); - self::assertEquals( - $expected_mod_text, - $actual_record->modtext - ); - - $deleted_user_records = $this->db()->get_records( - 'block_sharing_cart', - ['userid' => $deleted_user->id], - ); - - self::assertCount(0, $deleted_user_records); - - $this->db()->set_field( - 'config_plugins', - 'value', - $current_version, - ['plugin' => 'block_sharing_cart', 'name' => 'version'] - ); - } - - private function create_backup_file(array $record = []): stored_file - { - global $USER; - - $record['userid'] ??= $USER->id; - $record['contextid'] ??= context_user::instance($record['userid'])->id; - $record['component'] ??= storage::COMPONENT; - $record['filearea'] ??= storage::FILEAREA; - $record['itemid'] ??= storage::ITEMID; - $record['filepath'] ??= storage::FILEPATH; - $record['filename'] ??= hash('md5', random_bytes(16)) . '.mbz'; - $record['timecreated'] ??= time(); - $record['timemodified'] ??= $record['timecreated']; - - $content = $record['content'] ?? random_bytes(16); - $file = $this->storage->create_file_from_string((object)$record, $content); - - unset($record['content']); - - return $file; - } -}