Search moodle.org's
Developer Documentation

See Release Notes

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

Differences Between: [Versions 310 and 403] [Versions 311 and 403] [Versions 39 and 403] [Versions 400 and 403] [Versions 401 and 403]

   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 message_popup;
  18  
  19  use message_popup_external;
  20  use message_popup_test_helper;
  21  
  22  defined('MOODLE_INTERNAL') || die();
  23  
  24  global $CFG;
  25  
  26  require_once($CFG->dirroot . '/webservice/tests/helpers.php');
  27  require_once($CFG->dirroot . '/message/output/popup/externallib.php');
  28  require_once($CFG->dirroot . '/message/output/popup/tests/base.php');
  29  
  30  /**
  31   * Class for external message popup functions unit tests.
  32   *
  33   * @package    message_popup
  34   * @copyright  2016 Ryan Wyllie <ryan@moodle.com>
  35   * @license    http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later
  36   */
  37  class externallib_test extends \advanced_testcase {
  38      use message_popup_test_helper;
  39  
  40      /** @var \phpunit_message_sink message redirection. */
  41      public $messagesink;
  42  
  43      /**
  44       * Test set up.
  45       *
  46       * This is executed before running any test in this file.
  47       */
  48      public function setUp(): void {
  49          $this->preventResetByRollback(); // Messaging is not compatible with transactions.
  50          $this->messagesink = $this->redirectMessages();
  51          $this->resetAfterTest();
  52      }
  53  
  54      /**
  55       * Test that get_popup_notifications throws an exception if the user
  56       * doesn't exist.
  57       */
  58      public function test_get_popup_notifications_no_user_exception() {
  59          $this->resetAfterTest(true);
  60  
  61          $this->expectException('moodle_exception');
  62          $result = message_popup_external::get_popup_notifications(-2132131, false, 0, 0);
  63      }
  64  
  65      /**
  66       * get_popup_notifications should throw exception if user isn't logged in
  67       * user.
  68       */
  69      public function test_get_popup_notifications_access_denied_exception() {
  70          $this->resetAfterTest(true);
  71  
  72          $sender = $this->getDataGenerator()->create_user();
  73          $user = $this->getDataGenerator()->create_user();
  74  
  75          $this->setUser($user);
  76          $this->expectException('moodle_exception');
  77          $result = message_popup_external::get_popup_notifications($sender->id, false, 0, 0);
  78      }
  79  
  80      /**
  81       * get_popup_notifications should return notifications for the recipient.
  82       */
  83      public function test_get_popup_notifications_as_recipient() {
  84          $this->resetAfterTest(true);
  85  
  86          $sender = $this->getDataGenerator()->create_user(array('firstname' => 'Sendy', 'lastname' => 'Sender'));
  87          $recipient = $this->getDataGenerator()->create_user(array('firstname' => 'Recipy', 'lastname' => 'Recipient'));
  88  
  89          $notificationids = array(
  90              $this->send_fake_unread_popup_notification($sender, $recipient),
  91              $this->send_fake_unread_popup_notification($sender, $recipient),
  92              $this->send_fake_read_popup_notification($sender, $recipient),
  93              $this->send_fake_read_popup_notification($sender, $recipient),
  94          );
  95  
  96          // Confirm that admin has super powers to retrieve any notifications.
  97          $this->setAdminUser();
  98          $result = message_popup_external::get_popup_notifications($recipient->id, false, 0, 0);
  99          $this->assertCount(4, $result['notifications']);
 100          // Check we receive custom data as a unserialisable json.
 101          $found = 0;
 102          foreach ($result['notifications'] as $notification) {
 103              if (!empty($notification->customdata)) {
 104                  $this->assertObjectHasAttribute('datakey', json_decode($notification->customdata));
 105                  $found++;
 106              }
 107          }
 108          $this->assertEquals(2, $found);
 109  
 110          $this->setUser($recipient);
 111          $result = message_popup_external::get_popup_notifications($recipient->id, false, 0, 0);
 112          $this->assertCount(4, $result['notifications']);
 113      }
 114  
 115      /**
 116       * get_popup_notifications result set should work with limit and offset.
 117       */
 118      public function test_get_popup_notification_limit_offset() {
 119          $this->resetAfterTest(true);
 120  
 121          $sender = $this->getDataGenerator()->create_user(array('firstname' => 'Sendy', 'lastname' => 'Sender'));
 122          $recipient = $this->getDataGenerator()->create_user(array('firstname' => 'Recipy', 'lastname' => 'Recipient'));
 123  
 124          $this->setUser($recipient);
 125  
 126          $notificationids = array(
 127              $this->send_fake_unread_popup_notification($sender, $recipient, 'Notification 1', 1),
 128              $this->send_fake_unread_popup_notification($sender, $recipient, 'Notification 2', 2),
 129              $this->send_fake_unread_popup_notification($sender, $recipient, 'Notification 3', 3),
 130              $this->send_fake_unread_popup_notification($sender, $recipient, 'Notification 4', 4),
 131              $this->send_fake_read_popup_notification($sender, $recipient, 'Notification 5', 5),
 132              $this->send_fake_read_popup_notification($sender, $recipient, 'Notification 6', 6),
 133              $this->send_fake_read_popup_notification($sender, $recipient, 'Notification 7', 7),
 134              $this->send_fake_read_popup_notification($sender, $recipient, 'Notification 8', 8),
 135          );
 136  
 137          $result = message_popup_external::get_popup_notifications($recipient->id, true, 2, 0);
 138  
 139          $this->assertEquals($result['notifications'][0]->id, $notificationids[7]);
 140          $this->assertEquals($result['notifications'][1]->id, $notificationids[6]);
 141  
 142          $result = message_popup_external::get_popup_notifications($recipient->id, true, 2, 2);
 143  
 144          $this->assertEquals($result['notifications'][0]->id, $notificationids[5]);
 145          $this->assertEquals($result['notifications'][1]->id, $notificationids[4]);
 146      }
 147  
 148      /**
 149       * get_unread_popup_notification should throw an exception for an invalid user.
 150       */
 151      public function test_get_unread_popup_notification_count_invalid_user_exception() {
 152          $this->resetAfterTest(true);
 153  
 154          $this->expectException('moodle_exception');
 155          $result = message_popup_external::get_unread_popup_notification_count(-2132131, 0);
 156      }
 157  
 158      /**
 159       * get_unread_popup_notification_count should throw exception if being requested for
 160       * non-logged in user.
 161       */
 162      public function test_get_unread_popup_notification_count_access_denied_exception() {
 163          $this->resetAfterTest(true);
 164  
 165          $sender = $this->getDataGenerator()->create_user();
 166          $user = $this->getDataGenerator()->create_user();
 167  
 168          $this->setUser($user);
 169          $this->expectException('moodle_exception');
 170          $result = message_popup_external::get_unread_popup_notification_count($sender->id, 0);
 171      }
 172  
 173      /**
 174       * Test get_unread_popup_notification_count.
 175       */
 176      public function test_get_unread_popup_notification_count() {
 177          $this->resetAfterTest(true);
 178  
 179          $sender1 = $this->getDataGenerator()->create_user();
 180          $sender2 = $this->getDataGenerator()->create_user();
 181          $sender3 = $this->getDataGenerator()->create_user();
 182          $recipient = $this->getDataGenerator()->create_user();
 183  
 184          $this->setUser($recipient);
 185  
 186          $notificationids = array(
 187              $this->send_fake_unread_popup_notification($sender1, $recipient, 'Notification', 1),
 188              $this->send_fake_unread_popup_notification($sender1, $recipient, 'Notification', 2),
 189              $this->send_fake_unread_popup_notification($sender2, $recipient, 'Notification', 3),
 190              $this->send_fake_unread_popup_notification($sender2, $recipient, 'Notification', 4),
 191              $this->send_fake_unread_popup_notification($sender3, $recipient, 'Notification', 5),
 192              $this->send_fake_unread_popup_notification($sender3, $recipient, 'Notification', 6),
 193          );
 194  
 195          $count = message_popup_external::get_unread_popup_notification_count($recipient->id);
 196          $this->assertEquals($count, 6);
 197      }
 198  }