PageRenderTime 51ms CodeModel.GetById 16ms RepoModel.GetById 1ms app.codeStats 0ms

/mod/data/tests/events_test.php

http://github.com/moodle/moodle
PHP | 365 lines | 198 code | 58 blank | 109 comment | 1 complexity | 18808e0ecb201de7b888d9e6f5ec2696 MD5 | raw file
Possible License(s): MIT, AGPL-3.0, MPL-2.0-no-copyleft-exception, LGPL-3.0, GPL-3.0, Apache-2.0, LGPL-2.1, BSD-3-Clause
  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. * Events tests.
  18. *
  19. * @package mod_data
  20. * @category test
  21. * @copyright 2014 Mark Nelson <markn@moodle.com>
  22. * @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later
  23. */
  24. defined('MOODLE_INTERNAL') || die();
  25. global $CFG;
  26. class mod_data_events_testcase extends advanced_testcase {
  27. /**
  28. * Test set up.
  29. *
  30. * This is executed before running any test in this file.
  31. */
  32. public function setUp() {
  33. $this->resetAfterTest();
  34. }
  35. /**
  36. * Test the field created event.
  37. */
  38. public function test_field_created() {
  39. $this->setAdminUser();
  40. // Create a course we are going to add a data module to.
  41. $course = $this->getDataGenerator()->create_course();
  42. // The generator used to create a data module.
  43. $generator = $this->getDataGenerator()->get_plugin_generator('mod_data');
  44. // Create a data module.
  45. $data = $generator->create_instance(array('course' => $course->id));
  46. // Now we want to create a field.
  47. $field = data_get_field_new('text', $data);
  48. $fielddata = new stdClass();
  49. $fielddata->name = 'Test';
  50. $fielddata->description = 'Test description';
  51. $field->define_field($fielddata);
  52. // Trigger and capture the event for creating a field.
  53. $sink = $this->redirectEvents();
  54. $field->insert_field();
  55. $events = $sink->get_events();
  56. $event = reset($events);
  57. // Check that the event data is valid.
  58. $this->assertInstanceOf('\mod_data\event\field_created', $event);
  59. $this->assertEquals(context_module::instance($data->cmid), $event->get_context());
  60. $expected = array($course->id, 'data', 'fields add', 'field.php?d=' . $data->id . '&amp;mode=display&amp;fid=' .
  61. $field->field->id, $field->field->id, $data->cmid);
  62. $this->assertEventLegacyLogData($expected, $event);
  63. $this->assertEventContextNotUsed($event);
  64. $url = new moodle_url('/mod/data/field.php', array('d' => $data->id));
  65. $this->assertEquals($url, $event->get_url());
  66. }
  67. /**
  68. * Test the field updated event.
  69. */
  70. public function test_field_updated() {
  71. $this->setAdminUser();
  72. // Create a course we are going to add a data module to.
  73. $course = $this->getDataGenerator()->create_course();
  74. // The generator used to create a data module.
  75. $generator = $this->getDataGenerator()->get_plugin_generator('mod_data');
  76. // Create a data module.
  77. $data = $generator->create_instance(array('course' => $course->id));
  78. // Now we want to create a field.
  79. $field = data_get_field_new('text', $data);
  80. $fielddata = new stdClass();
  81. $fielddata->name = 'Test';
  82. $fielddata->description = 'Test description';
  83. $field->define_field($fielddata);
  84. $field->insert_field();
  85. // Trigger and capture the event for updating the field.
  86. $sink = $this->redirectEvents();
  87. $field->update_field();
  88. $events = $sink->get_events();
  89. $event = reset($events);
  90. // Check that the event data is valid.
  91. $this->assertInstanceOf('\mod_data\event\field_updated', $event);
  92. $this->assertEquals(context_module::instance($data->cmid), $event->get_context());
  93. $expected = array($course->id, 'data', 'fields update', 'field.php?d=' . $data->id . '&amp;mode=display&amp;fid=' .
  94. $field->field->id, $field->field->id, $data->cmid);
  95. $this->assertEventLegacyLogData($expected, $event);
  96. $this->assertEventContextNotUsed($event);
  97. $url = new moodle_url('/mod/data/field.php', array('d' => $data->id));
  98. $this->assertEquals($url, $event->get_url());
  99. }
  100. /**
  101. * Test the field deleted event.
  102. */
  103. public function test_field_deleted() {
  104. $this->setAdminUser();
  105. // Create a course we are going to add a data module to.
  106. $course = $this->getDataGenerator()->create_course();
  107. // The generator used to create a data module.
  108. $generator = $this->getDataGenerator()->get_plugin_generator('mod_data');
  109. // Create a data module.
  110. $data = $generator->create_instance(array('course' => $course->id));
  111. // Now we want to create a field.
  112. $field = data_get_field_new('text', $data);
  113. $fielddata = new stdClass();
  114. $fielddata->name = 'Test';
  115. $fielddata->description = 'Test description';
  116. $field->define_field($fielddata);
  117. $field->insert_field();
  118. // Trigger and capture the event for deleting the field.
  119. $sink = $this->redirectEvents();
  120. $field->delete_field();
  121. $events = $sink->get_events();
  122. $event = reset($events);
  123. // Check that the event data is valid.
  124. $this->assertInstanceOf('\mod_data\event\field_deleted', $event);
  125. $this->assertEquals(context_module::instance($data->cmid), $event->get_context());
  126. $expected = array($course->id, 'data', 'fields delete', 'field.php?d=' . $data->id, $field->field->name, $data->cmid);
  127. $this->assertEventLegacyLogData($expected, $event);
  128. $this->assertEventContextNotUsed($event);
  129. $url = new moodle_url('/mod/data/field.php', array('d' => $data->id));
  130. $this->assertEquals($url, $event->get_url());
  131. }
  132. /**
  133. * Test the record created event.
  134. */
  135. public function test_record_created() {
  136. // Create a course we are going to add a data module to.
  137. $course = $this->getDataGenerator()->create_course();
  138. // The generator used to create a data module.
  139. $generator = $this->getDataGenerator()->get_plugin_generator('mod_data');
  140. // Create a data module.
  141. $data = $generator->create_instance(array('course' => $course->id));
  142. // Trigger and capture the event for creating the record.
  143. $sink = $this->redirectEvents();
  144. $recordid = data_add_record($data);
  145. $events = $sink->get_events();
  146. $event = reset($events);
  147. // Check that the event data is valid.
  148. $this->assertInstanceOf('\mod_data\event\record_created', $event);
  149. $this->assertEquals(context_module::instance($data->cmid), $event->get_context());
  150. $expected = array($course->id, 'data', 'add', 'view.php?d=' . $data->id . '&amp;rid=' . $recordid,
  151. $data->id, $data->cmid);
  152. $this->assertEventLegacyLogData($expected, $event);
  153. $this->assertEventContextNotUsed($event);
  154. $url = new moodle_url('/mod/data/view.php', array('d' => $data->id, 'rid' => $recordid));
  155. $this->assertEquals($url, $event->get_url());
  156. }
  157. /**
  158. * Test the record updated event.
  159. *
  160. * There is no external API for updating a record, so the unit test will simply create
  161. * and trigger the event and ensure the legacy log data is returned as expected.
  162. */
  163. public function test_record_updated() {
  164. // Create a course we are going to add a data module to.
  165. $course = $this->getDataGenerator()->create_course();
  166. // The generator used to create a data module.
  167. $generator = $this->getDataGenerator()->get_plugin_generator('mod_data');
  168. // Create a data module.
  169. $data = $generator->create_instance(array('course' => $course->id));
  170. // Trigger an event for updating this record.
  171. $event = \mod_data\event\record_updated::create(array(
  172. 'objectid' => 1,
  173. 'context' => context_module::instance($data->cmid),
  174. 'courseid' => $course->id,
  175. 'other' => array(
  176. 'dataid' => $data->id
  177. )
  178. ));
  179. // Trigger and capture the event for updating the data record.
  180. $sink = $this->redirectEvents();
  181. $event->trigger();
  182. $events = $sink->get_events();
  183. $event = reset($events);
  184. // Check that the event data is valid.
  185. $this->assertInstanceOf('\mod_data\event\record_updated', $event);
  186. $this->assertEquals(context_module::instance($data->cmid), $event->get_context());
  187. $expected = array($course->id, 'data', 'update', 'view.php?d=' . $data->id . '&amp;rid=1', $data->id, $data->cmid);
  188. $this->assertEventLegacyLogData($expected, $event);
  189. $this->assertEventContextNotUsed($event);
  190. $url = new moodle_url('/mod/data/view.php', array('d' => $data->id, 'rid' => $event->objectid));
  191. $this->assertEquals($url, $event->get_url());
  192. }
  193. /**
  194. * Test the record deleted event.
  195. */
  196. public function test_record_deleted() {
  197. global $DB;
  198. // Create a course we are going to add a data module to.
  199. $course = $this->getDataGenerator()->create_course();
  200. // The generator used to create a data module.
  201. $generator = $this->getDataGenerator()->get_plugin_generator('mod_data');
  202. // Create a data module.
  203. $data = $generator->create_instance(array('course' => $course->id));
  204. // Now we want to create a field.
  205. $field = data_get_field_new('text', $data);
  206. $fielddata = new stdClass();
  207. $fielddata->name = 'Test';
  208. $fielddata->description = 'Test description';
  209. $field->define_field($fielddata);
  210. $field->insert_field();
  211. // Create data record.
  212. $datarecords = new stdClass();
  213. $datarecords->userid = '2';
  214. $datarecords->dataid = $data->id;
  215. $datarecords->id = $DB->insert_record('data_records', $datarecords);
  216. // Create data content.
  217. $datacontent = new stdClass();
  218. $datacontent->fieldid = $field->field->id;
  219. $datacontent->recordid = $datarecords->id;
  220. $datacontent->id = $DB->insert_record('data_content', $datacontent);
  221. // Trigger and capture the event for deleting the data record.
  222. $sink = $this->redirectEvents();
  223. data_delete_record($datarecords->id, $data, $course->id, $data->cmid);
  224. $events = $sink->get_events();
  225. $event = reset($events);
  226. // Check that the event data is valid.
  227. $this->assertInstanceOf('\mod_data\event\record_deleted', $event);
  228. $this->assertEquals(context_module::instance($data->cmid), $event->get_context());
  229. $expected = array($course->id, 'data', 'record delete', 'view.php?id=' . $data->cmid, $data->id, $data->cmid);
  230. $this->assertEventLegacyLogData($expected, $event);
  231. $this->assertEventContextNotUsed($event);
  232. $url = new moodle_url('/mod/data/view.php', array('d' => $data->id));
  233. $this->assertEquals($url, $event->get_url());
  234. }
  235. /**
  236. * Test the template viewed event.
  237. *
  238. * There is no external API for viewing templates, so the unit test will simply create
  239. * and trigger the event and ensure the legacy log data is returned as expected.
  240. */
  241. public function test_template_viewed() {
  242. // Create a course we are going to add a data module to.
  243. $course = $this->getDataGenerator()->create_course();
  244. // The generator used to create a data module.
  245. $generator = $this->getDataGenerator()->get_plugin_generator('mod_data');
  246. // Create a data module.
  247. $data = $generator->create_instance(array('course' => $course->id));
  248. // Trigger an event for updating this record.
  249. $event = \mod_data\event\template_viewed::create(array(
  250. 'context' => context_module::instance($data->cmid),
  251. 'courseid' => $course->id,
  252. 'other' => array(
  253. 'dataid' => $data->id
  254. )
  255. ));
  256. // Trigger and capture the event for updating the data record.
  257. $sink = $this->redirectEvents();
  258. $event->trigger();
  259. $events = $sink->get_events();
  260. $event = reset($events);
  261. // Check that the event data is valid.
  262. $this->assertInstanceOf('\mod_data\event\template_viewed', $event);
  263. $this->assertEquals(context_module::instance($data->cmid), $event->get_context());
  264. $expected = array($course->id, 'data', 'templates view', 'templates.php?id=' . $data->cmid . '&amp;d=' .
  265. $data->id, $data->id, $data->cmid);
  266. $this->assertEventLegacyLogData($expected, $event);
  267. $this->assertEventContextNotUsed($event);
  268. $url = new moodle_url('/mod/data/templates.php', array('d' => $data->id));
  269. $this->assertEquals($url, $event->get_url());
  270. }
  271. /**
  272. * Test the template updated event.
  273. *
  274. * There is no external API for updating a template, so the unit test will simply create
  275. * and trigger the event and ensure the legacy log data is returned as expected.
  276. */
  277. public function test_template_updated() {
  278. // Create a course we are going to add a data module to.
  279. $course = $this->getDataGenerator()->create_course();
  280. // The generator used to create a data module.
  281. $generator = $this->getDataGenerator()->get_plugin_generator('mod_data');
  282. // Create a data module.
  283. $data = $generator->create_instance(array('course' => $course->id));
  284. // Trigger an event for updating this record.
  285. $event = \mod_data\event\template_updated::create(array(
  286. 'context' => context_module::instance($data->cmid),
  287. 'courseid' => $course->id,
  288. 'other' => array(
  289. 'dataid' => $data->id,
  290. )
  291. ));
  292. // Trigger and capture the event for updating the data record.
  293. $sink = $this->redirectEvents();
  294. $event->trigger();
  295. $events = $sink->get_events();
  296. $event = reset($events);
  297. // Check that the event data is valid.
  298. $this->assertInstanceOf('\mod_data\event\template_updated', $event);
  299. $this->assertEquals(context_module::instance($data->cmid), $event->get_context());
  300. $expected = array($course->id, 'data', 'templates saved', 'templates.php?id=' . $data->cmid . '&amp;d=' .
  301. $data->id, $data->id, $data->cmid);
  302. $this->assertEventLegacyLogData($expected, $event);
  303. $this->assertEventContextNotUsed($event);
  304. $url = new moodle_url('/mod/data/templates.php', array('d' => $data->id));
  305. $this->assertEquals($url, $event->get_url());
  306. }
  307. }