Search moodle.org's
Developer Documentation

See Release Notes

  • Bug fixes for general core bugs in 4.2.x will end 22 April 2024 (12 months).
  • Bug fixes for security issues in 4.2.x will end 7 October 2024 (18 months).
  • PHP version: minimum PHP 8.0.0 Note: minimum PHP version has increased since Moodle 4.1. PHP 8.1.x is supported too.

Differences Between: [Versions 310 and 402] [Versions 39 and 402]

   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   * Unit tests for importziplib.
  19   *
  20   * @package    assignfeedback_file
  21   * @copyright  2020 Eric Merrill <merrill@oakland.edu>
  22   * @license    http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later
  23   */
  24  
  25  namespace assignfeedback_file;
  26  
  27  use mod_assign_test_generator;
  28  
  29  defined('MOODLE_INTERNAL') || die();
  30  
  31  global $CFG;
  32  require_once($CFG->dirroot . '/mod/assign/tests/generator.php');
  33  require_once($CFG->dirroot . '/mod/assign/feedback/file/importziplib.php');
  34  
  35  /**
  36   * Unit tests for importziplib.
  37   *
  38   * @package    assignfeedback_file
  39   * @copyright  2020 Eric Merrill <merrill@oakland.edu>
  40   * @license    http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later
  41   */
  42  class importziplib_test extends \advanced_testcase {
  43  
  44      // Use the generator helper.
  45      use mod_assign_test_generator;
  46  
  47      /**
  48       * Test the assignfeedback_file_zip_importer->is_valid_filename_for_import() method.
  49       */
  50      public function test_is_valid_filename_for_import() {
  51          // Do the initial assign setup.
  52          $this->resetAfterTest();
  53          $course = $this->getDataGenerator()->create_course();
  54          $teacher = $this->getDataGenerator()->create_and_enrol($course, 'teacher');
  55          $student = $this->getDataGenerator()->create_and_enrol($course, 'student');
  56  
  57          $assign = $this->create_instance($course, [
  58                  'assignsubmission_onlinetext_enabled' => 1,
  59                  'assignfeedback_file_enabled' => 1,
  60              ]);
  61  
  62          // Create an online text submission.
  63          $this->add_submission($student, $assign);
  64  
  65          // Now onto the file work.
  66          $fs = get_file_storage();
  67  
  68          // Setup a basic file we will work with. We will keep renaming and repathing it.
  69          $record = new \stdClass;
  70          $record->contextid = $assign->get_context()->id;
  71          $record->component = 'assignfeedback_file';
  72          $record->filearea  = ASSIGNFEEDBACK_FILE_FILEAREA;
  73          $record->itemid    = $assign->get_user_grade($student->id, true)->id;
  74          $record->filepath  = '/';
  75          $record->filename  = '1.txt';
  76          $record->source    = 'test';
  77          $file = $fs->create_file_from_string($record, 'file content');
  78  
  79          // The importer we will use.
  80          $importer = new \assignfeedback_file_zip_importer();
  81  
  82          // Setup some variable we use.
  83          $user = null;
  84          $plugin = null;
  85          $filename = '';
  86  
  87          $allusers = $assign->list_participants(0, false);
  88          $participants = array();
  89          foreach ($allusers as $user) {
  90              $participants[$assign->get_uniqueid_for_user($user->id)] = $user;
  91          }
  92  
  93          $file->rename('/import/', '.hiddenfile');
  94          $result = $importer->is_valid_filename_for_import($assign, $file, $participants, $user, $plugin, $filename);
  95          $this->assertFalse($result);
  96  
  97          $file->rename('/import/', '~hiddenfile');
  98          $result = $importer->is_valid_filename_for_import($assign, $file, $participants, $user, $plugin, $filename);
  99          $this->assertFalse($result);
 100  
 101          $file->rename('/import/some_path_here/', 'RandomFile.txt');
 102          $result = $importer->is_valid_filename_for_import($assign, $file, $participants, $user, $plugin, $filename);
 103          $this->assertFalse($result);
 104  
 105          $file->rename('/import/', '~hiddenfile');
 106          $result = $importer->is_valid_filename_for_import($assign, $file, $participants, $user, $plugin, $filename);
 107          $this->assertFalse($result);
 108  
 109          // Get the students assign id.
 110          $studentid = $assign->get_uniqueid_for_user($student->id);
 111  
 112          // Submissions are identified with the format:
 113          // StudentName_StudentID_PluginType_Plugin_FilePathAndName.
 114  
 115          // Test a string student id.
 116          $badname = 'Student Name_StringID_assignsubmission_file_My_cool_filename.txt';
 117          $file->rename('/import/', $badname);
 118          $result = $importer->is_valid_filename_for_import($assign, $file, $participants, $user, $plugin, $filename);
 119          $this->assertFalse($result);
 120  
 121          // Test an invalid student id.
 122          $badname = 'Student Name_' . ($studentid + 100) . '_assignsubmission_file_My_cool_filename.txt';
 123          $file->rename('/import/', $badname);
 124          $result = $importer->is_valid_filename_for_import($assign, $file, $participants, $user, $plugin, $filename);
 125          $this->assertFalse($result);
 126  
 127          // Test an invalid submission plugin.
 128          $badname = 'Student Name_' . $studentid . '_assignsubmission_noplugin_My_cool_filename.txt';
 129          $file->rename('/import/', $badname);
 130          $result = $importer->is_valid_filename_for_import($assign, $file, $participants, $user, $plugin, $filename);
 131          $this->assertFalse($result);
 132  
 133          // Test a basic, good file.
 134          $goodbase = 'Student Name_' . $studentid . '_assignsubmission_file_';
 135          $file->rename('/import/', $goodbase . "My_cool_filename.txt");
 136          $result = $importer->is_valid_filename_for_import($assign, $file, $participants, $user, $plugin, $filename);
 137          $this->assertTrue($result);
 138          $this->assertEquals($participants[$studentid], $user);
 139          $this->assertEquals('My_cool_filename.txt', $filename);
 140          $this->assertInstanceOf(\assign_submission_file::class, $plugin);
 141  
 142          // Test another good file, with some additional path and underscores.
 143          $user = null;
 144          $plugin = null;
 145          $filename = '';
 146          $file->rename('/import/some_path_here/' . $goodbase . '/some_path/', 'My File.txt');
 147          $result = $importer->is_valid_filename_for_import($assign, $file, $participants, $user, $plugin, $filename);
 148          $this->assertTrue($result);
 149          $this->assertEquals($participants[$studentid], $user);
 150          $this->assertEquals('/some_path/My File.txt', $filename);
 151          $this->assertInstanceOf(\assign_submission_file::class, $plugin);
 152      }
 153  }