Proyectos de Subversion Moodle

Rev

Rev 1 | | Comparar con el anterior | Ultima modificación | Ver Log |

Rev Autor Línea Nro. Línea
1441 ariadna 1
=== 4.5 Onwards ===
2
 
3
This file has been replaced by UPGRADING.md. See MDL-81125 for further information.
4
 
5
===
1 efrain 6
This files describes API changes for code that uses the question API.
7
 
8
=== 4.4 ===
9
* The following previously deprecated methods have been removed and can no longer be used:
10
  - `submit_tags_form`
11
  - `get_bulk_action_key`
12
  - `preview_question_url`
13
  - `process_actions`
14
  - `process_actions_needing_ui`
15
  - `question_is_only_child_of_top_category_in_context`
16
  - `question_is_top_category`
17
  - `question_can_delete_cat`
18
  - `print_choose_qtype_to_add_form`
19
  - `create_new_question_button`
20
  - `question_preview_link`
21
  - `core_question_output_fragment_tags_form`
22
  - `render_qbank_chooser`
23
  - `qbank_chooser`
24
  - `qbank_chooser_types`
25
  - `qbank_chooser_qtype`
26
  - `qbank_chooser_title`
27
 
28
* The following previously deprecated files have been removed and can no longer be used:
29
  - `question/amd/src/edit_tags.js`
30
  - `question/amd/src/repository.js`
31
  - `question/amd/src/selectors.js`
32
  - `question/category_class.php`
33
  - `question/category_form.php`
34
  - `question/export_form.php`
35
  - `question/import_form.php`
36
  - `question/move_form.php`
37
  - `question/previewlib.php`
38
  - `question/yui/src/preview/js/preview.js`
39
 
40
* The following previously deprecated JS functions have been removed and can no longer be used:
41
  - `M.core_scroll_manager.scroll_to_saved_pos`
42
  - `M.core_question_engine.init_form`
43
  - `M.core_question_engine.prevent_repeat_submission`
44
 
45
=== 4.3 ===
46
 
47
1) The core_question_generator::update_question has been changed so that it no longer modifies the $question
48
   object that was passed in. Instead, the update question is returned (which was already the case).
49
   If you were relying on the old behavioru in your tests, you will need a change like
50
       $questiongenerator->update_question($question, ...);
51
   to
52
       $question = $questiongenerator->update_question($question, ...);
53
   Also, the $question object returned now has fields questionbankentryid, versionid, version and status.
54
 
55
2) question_stats_cleanup_task has been removed. It is no longer required. Instead,
56
   older statistics are deleted whenever a new set are calculated for a particular quiz.
57
 
58
3) In the past, the methods get_last_calculated_time() and get_cached() of \core_question\statistics\responses\analyser
59
   and \core_question\statistics\questions\all_calculated_for_qubaid_condition
60
   only returned the pre-computed statistics if they were computed less than 15 minutes ago. Now, they will
61
   always return any computed statistics that exist. Therefore, the constants TIME_TO_CACHE in those classes
62
   have been deprecated.
63
 
64
4) The cache() methods of classes analysis_for_question, analysis_for_subpart, analysis_for_class
65
   and analysis_for_actual_response now take an optional $calculationtime, which is used the time
66
   stored in the database. If not given, time() is used.
67
 
68
5) The "Start again with these options" text is changed "Save preview options and start again". If you use this text in behat test, please use the new text
69
   or use the id of the button id_saverestart instead.
70
 
71
6) The question bank tertiary navigation is now built using the `plugin_feature::get_navigation_node()` functions from qbank plugins.
72
   This allows plugins to extend the navigation with their own links.
73
 
74
7) The tertiary navigation now allows pages to add their own action button next to the navigation menu by calling
75
   `set_action_button()` on the `qbank_action_menu` object. This means plugin pages can include their own button like the
76
   category management page has "Add category".
77
 
78
8) The question bank view now has additional hooks for qbank plugins to modify how the question bank is displayed.
79
   `\core_question\local\bank\column_manager_base` defines methods for setting the order, visibility and width of columns, and
80
   for providing a list of actions to be displayed in each column's header. Any qbank plugin can return a subclass of this from
81
   its `plugin_features::get_column_manager()` method to implement its own logic for these methods. Only one column manager can be
82
   active at a time, so in the case of multiple enabled plugins providing a column manager, the first one will be used by component
83
   name sorted alphabetically.
84
   Plugins can also define `plugin_features::get_question_bank_controls()` returning a list of renderables that will be displayed
85
   above the question bank table, to provide additional functionality on the question bank page.
86
 
87
9) CSS selectors using #categoryquestions to address the table on the question bank page have now been changed to use
88
  .question-bank-table. This applies to the same styles to preview on the qbank_columnsortorder admin screen. It is important
89
  that the styles match on these pages so that the defaults have the expected result in the question bank.
90
 
91
=== 4.2 ===
92
 
93
1) The question/qengine.js has been deprecated. We create core_question/question_engine
94
   and core/scroll_manager to replace it.
95
 
96
2) For properties that were previously only declared dynamically, a few classes now include property declarations to support PHP 8.2.
97
   The affected classes are:
98
   * restore_qbank_customfields_plugin
99
   * category_condition
100
   * tag_condition
101
   * question_behaviour_attempt_updater
102
   * question_engine_attempt_upgrader
103
   * qformat_blackboard_six
104
   * qtype_multianswer_edit_form
105
   * qtype_ddimageortext_drop_zone
106
   * qtype_randomsamatch_qe2_attempt_updater
107
   * qformat_default
108
 
109
   Some existing code and variables must be removed while working on this issue, including:
110
   * Removed $replace in class qtype_calculated_variable_substituter
111
   * Removed $wizarddisplay qtype_calculatedsimple_edit_form::definition_inner()
112
   * Removed '$question->places[$placeno]->fieldname = $fieldname' in qtype_ddtoimage_renderer_base::formulation_and_controls()
113
   * Removed $mc->single in qtype_multianswer_test_helper::make_multianswer_question_multiple()
114
 
115
3) display_move_form() in qbank_managecategories\question_category_object class is deprecated and moved the logic to
116
   the question/bank/managecategories/category.php.
117
 
118
=== 4.1 ===
119
 
120
1) get_bulk_action_key() in core_question\local\bank\bulk_action_base class is deprecated and renamed to get_key().
121
 
122
=== 4.0.5 ===
123
 
124
1) Question bank plugins can now define more than one bulk action. Therefore, plugin_features_base::get_bulk_actions has been
125
   changed to return an array, rather than a single bulk action class. Please update the plugin_features class in your plugin if necessary.
126
 
127
=== 4.0 ===
128
 
129
Moodle 4.0 included the results of a major project to re-work the question bank.
130
 
131
1) Database changes (as usual, all existing data is updated automatically).
132
   * Previously there was a single {question} table. This has now been split into three to handle versionning questions:
133
     - question              - This now has a row for each version of each question. Therefore, some of the metadata
134
                               (e.g. category) is moved to the next table. However, data that defines how a question works
135
                               is unchanged, so question type plugins will mostly keep working.
136
     - question_bank_entries - Each question bank entry is a question that appears in the question bank, which can
137
                               have many versions.
138
     - question_versions     - This joins all the versions of a question in the {question} table to the
139
                               {question_bank_entries} row they belong to.
140
   * Also, how other parts of the code refer to questions they want to to has changed, to be managed by the core
141
     API in two new tables.
142
      - question_references -> Records where a specific question is used.
143
      - question_set_references -> Records where groups of questions are used (for example random questions in quizzes).
144
     As a result of this, data from the two quiz tables {quiz_slot} and {quiz_slot_tags} was moved to these new tables.
145
 
146
2) There is a new plugin type 'qbank' for adding features to the question bank. See question/bank/upgrade.txt.
147
 
148
3) Many previously core features have been moved into new plugins, meaning that many old functionsand classes in
149
   lib/questionlib.php and other locations have been deprecated and moved:
150
    * Moved to qbank_previewquestion:
151
       - question_preview_url() is moved to qbank_previewquestion\helper::question_preview_url()
152
       - question_preview_popup_params() is moved to qbank_previewquestion\helper::question_preview_popup_params()
153
      the following were really part of the internal implementation of preview, so should not have been used elsewhere,
154
      but they were also moved (from previewlib.php).
155
       - restart_preview() => qbank_previewquestion\helper::restart_preview(),
156
       - question_preview_form_url() => qbank_previewquestion\helper::question_preview_form_url(),
157
       - question_preview_action_url() => qbank_previewquestion\helper::question_preview_action_url(),
158
       - question_preview_question_pluginfile() => qbank_previewquestion\helper::question_preview_question_pluginfile(),
159
       - class preview_options_form => 'qbank_previewquestion\form\preview_options_form',
160
       - class question_preview_options => 'qbank_previewquestion\output\question_preview_options',
161
    * Moved to qbank_managecategories:
162
       - qbank_managecategories\helper::question_remove_stale_questions_from_category()
163
       - flatten_category_tree() => qbank_managecategories\helper::flatten_category_tree()
164
       - add_indented_names() => qbank_managecategories\helper::add_indented_names()
165
       - question_category_select_menu() => qbank_managecategories\helper::question_category_select_menu()
166
       - get_categories_for_contexts() => qbank_managecategories\helper::get_categories_for_contexts()
167
       - question_category_options() => qbank_managecategories\helper::question_category_options()
168
       - question_add_context_in_key() => qbank_managecategories\helper::question_add_context_in_key()
169
       - question_fix_top_names() => qbank_managecategories\helper::question_fix_top_names()
170
       - class category_form => qbank_managecategories\form\category_form
171
       - class question_category_list => qbank_managecategories\question_category_list
172
       - class question_category_list_item => 'bank_managecategories\question_category_list_item
173
       - class question_category_object => qbank_managecategories\question_category_object
174
       - class question_category_edit_form => qbank_managecategories\form\category_form
175
       - class question_move_form => qbank_managecategories\form\question_move_form
176
    * Moved to qbank_exporttoxml:
177
       - question_get_export_single_question_url() -> qbank_exporttoxml\helper::question_get_export_single_question_url().
178
    * Moved to qbank_exportquestions:
179
       - class question_export_form => qbank_exportquestions\form\export_form
180
       - class export_form => qbank_exportquestions\form\export_form
181
    * Moved to qbank_importquestions:
182
       - class question_import_form => qbank_importquestions\form\question_import_form
183
    * Moved to qbank_tagquestion:
184
       - submit_tags_form and associated external services for question tag,
185
       - tags_form in question/type,
186
       - core_question_output_fragment_tags_form() => /question/bank/qbank_tagquestion/lib.php.
187
 
188
4) The following functions in questionlib.php now using type hinting. So, if you call them with the wrong types,
189
   you will now get fatal errors.
190
    - is_latest()
191
    - get_next_version()
192
    - get_question_version()
193
    - get_question_bank_entry()
194
    - core_question_find_next_unused_idnumber()
195
    - question_module_uses_questions()
196
    - question_page_type_list()
197
    - core_question_question_preview_pluginfile()
198
    - question_rewrite_question_preview_urls()
199
    - question_rewrite_question_urls()
200
    - question_get_all_capabilities()
201
    - question_get_question_capabilities()
202
    - question_require_capability_on()
203
    - question_has_capability_on()
204
    - question_default_export_filename()
205
    - get_import_export_formats()
206
    - question_categorylist_parents()
207
    - question_categorylist()
208
    - question_make_default_categories()
209
    - question_get_top_categories_for_contexts()
210
    - sort_categories_by_tree()
211
    - print_question_icon()
212
    - question_sort_tags()
213
    - _tidy_question()
214
    - question_preload_questions()
215
    - question_move_category_to_context()
216
    - move_question_set_references()
217
    - question_move_questions_to_category()
218
    - idnumber_exist_in_question_category()
219
    - question_move_question_tags_to_new_context()
220
    - question_delete_activity()
221
    - question_delete_course_category()
222
    - question_delete_course()
223
    - question_delete_context()
224
    - question_delete_question()
225
    - delete_question_bank_entry()
226
    - question_category_in_use()
227
    - question_category_delete_safe()
228
    - question_context_has_any_questions()
229
    - questions_in_use()
230
    - question_save_qtype_order()
231
    - question_reorder_qtypes()
232
 
233
5) Function question_hash() from questionlib.php is deprecated without replacement.
234
 
235
6) The following classes have been moved, to better follow Moodle's name-space usage rules:
236
   'core_question\bank\action_column_base' => 'core_question\local\bank\action_column_base',
237
   'core_question\bank\checkbox_column' => 'core_question\local\bank\checkbox_column',
238
   'core_question\bank\column_base' => 'core_question\local\bank\column_base',
239
   'core_question\bank\edit_menu_column' => 'core_question\local\bank\edit_menu_column',
240
   'core_question\bank\menu_action_column_base' => 'core_question\local\bank\menu_action_column_base',
241
   'core_question\bank\menuable_action' => 'core_question\local\bank\menuable_action',
242
   'core_question\bank\random_question_loader' => 'core_question\local\bank\random_question_loader',
243
   'core_question\bank\row_base' => 'core_question\local\bank\row_base',
244
   'core_question\bank\view' => 'core_question\local\bank\view',
245
   'core_question\bank\copy_action_column' => 'qbank_editquestion\copy_action_column',
246
   'core_question\bank\edit_action_column' => 'qbank_editquestion\edit_action_column',
247
   'core_question\bank\creator_name_column' => 'qbank_viewcreator\creator_name_column',
248
   'core_question\bank\question_name_column' => 'qbank_viewquestionname\viewquestionname_column_helper',
249
   'core_question\bank\question_name_idnumber_tags_column' => 'qbank_viewquestionname\question_name_idnumber_tags_column',
250
   'core_question\bank\delete_action_column' => 'qbank_deletequestion\delete_action_column',
251
   'core_question\bank\export_xml_action_column' => 'qbank_exporttoxml\export_xml_action_column',
252
   'core_question\bank\preview_action_column' => 'qbank_previewquestion\preview_action_column',
253
   'core_question\bank\question_text_row' => 'qbank_viewquestiontext\question_text_row',
254
   'core_question\bank\question_type_column' => 'qbank_viewquestiontype\question_type_column',
255
   'core_question\bank\tags_action_column' => 'qbank_tagquestion\tags_action_column',
256
   'core_question\form\tags' => '\qbank_tagquestion\form\tags_form',
257
   'core_question\output\qbank_chooser' => 'qbank_editquestion\qbank_chooser',
258
   'core_question\output\qbank_chooser_item' => 'qbank_editquestion\qbank_chooser_item',
259
 
260
7) The Behat class for question-related steps has been renamed to behat_core_question
261
    to match the expected naming convention. In the unlikely event that you are directly
262
    referring to the behat_question class name (nothing in the standard Moodle code was)
263
    then you will have to update your reference.
264
 
265
 
266
=== 3.9 ===
267
 
268
1) For years, the ..._questions_in_use callback has been the right way for plugins to
269
   tell the core question system if questions are required. Previously this callback
270
   only worked in mods. Now it works in all plugins.
271
 
272
   At the same time, if you are still relying on the legacy ..._question_list_instances
273
   callback for this, you will now get a debugging warning telling you to upgrade.
274
 
275
2) Previously, the functions question_delete_activity, question_delete_course and
276
   question_delete_course_category would echo output. This was not correct behaviour for
277
   a low-level API function. Now, they no longer output. Related to this, the helper
278
   function they use, question_delete_context, now always returns an empty array.
279
 
280
   This probably won't acutally cause you any problems. However, you may previously
281
   have had to add expectOutputRegex calls to your unit tests to avoid warnings about
282
   risky tests. If you have done that, those tests will now fail until you delete that expectation.
283
 
284
 
285
=== 3.8 ===
286
 
287
If you have customised the display of the question bank (using $CFG->questionbankcolumns)
288
then be aware that the default configuration has changed, and you may wish to make
289
equivalent changes in your customised version. The old column question_name_column
290
has been replaced by question_name_idnumber_tags_column. The old question_name_column
291
still exists, so it is safe to continue using it.
292
 
293
There is a new question bank column edit_menu_column which displays all actions
294
in a drop-down menu, instead of as separate icons. This is now used by default.
295
Specifically, it gathers all other columns which implement the new interface
296
menuable_action. If you have made a custom subclasses of action_column_base,
297
you probably want to implement the new interface. If your column is a simple action,
298
the easiest way to do this will be to subclass menu_action_column_base. If your action
299
is more complex, and does not follow the simple pattern that menu_action_column_base
300
uses, then you will need to implement menuable_action yourself. The commit for
301
MDL-66816 updates all the core action columns. Looking at that change should make
302
it clearly the changes you need to make to your columns.
303
 
304
 
305
=== 3.7 ===
306
 
307
The code for the is_valid_number function that was duplicated in the
308
qtype_numerical and qtype_multianswer plugins in the qtype_numerical_edit_form
309
and qtype_multianswer_edit_form classes has been moved to a static function
310
in the qtype_numerical class of the qtype_numerical plugin.
311
 
312
The exportprocess function of the qformat_default class doesn't output a blank line
313
if the result of the writequestion function is null. This permit to qformat plugins
314
to ignore some questions without the need to overwrite this function.
315
 
316
* The question_preview_cron() has been deleted. Please use \core\task\question_cron_task::execute().
317
* The question_usage_statistics_cron() has been deleted. Please use \core\task\question_cron_task::execute().
318
* The method question_bank::cron() has been deleted, please use question related scheduled tasks.
319
 
320
=== 3.5 ===
321
 
322
1) The question format exportprocess function now adds a
323
   $checkcapabilities boolean to allow questions to be exported in
324
   certain circumstances.
325
 
326
=== 3.2 ===
327
 
328
1) The following renderers have been deprecated in favour of the renderable
329
   core_question\output\qbank_chooser and associated render_* method.
330
    * qbank_chooser
331
    * qbank_chooser_types
332
    * qbank_chooser_qtype
333
    * qbank_chooser_title
334
 
335
=== 3.1 ===
336
 
337
1) The argument $requirecourseid was removed from question_edit_setup() and
338
   is no longer respected. The behaviour was found to be buggy and now throws
339
   debugging notices if passed.
340
 
341
=== 2.9 ===
342
 
343
1) Some functions in questionlib.php which were deprecated in the past have now
344
   been deleted:
345
 
346
   Deprecated since 2.1
347
    * question_list_instances
348
    * get_grade_options
349
    * question_category_isused
350
    * save_question_options
351
    * question_get_real_state
352
 
353
   Deprecated since 2.6
354
    * question_rewrite_questiontext_preview_urls
355
    * question_send_questiontext_file
356
    * question_pluginfile no longer falls back to using the old
357
      {$previewcomponent}_questiontext_preview_pluginfile callback if the new
358
      {$previewcomponent}_question_preview_pluginfile callback is missing.
359
 
360
 
361
=== 2.8 ===
362
 
363
1) This is just a warning that some methods of the question_engine_data_mapper
364
   class have changed. All these methods are ones that you should not have been
365
   calling directly from your code, so this should not cause any problems.
366
   The changed methods are:
367
    * insert_question_attempt
368
    * insert_step_data
369
    * update_question_attempt_step
370
 
371
 
372
=== 2.7 ===
373
 
374
1)  Changes to class question_bank_view:
375
 
376
    Filters, including $recurse and $showhidden, are now implemented as
377
    pluggable \core_question\bank\search\condition classes.
378
 
379
    Therefore $recurse and $showhidden are no longer passed to the following functions:
380
        protected function display_options [deprecated, use display_options_form()]
381
        protected function build_query_sql [deprecated, use build_query()]
382
 
383
    protected function display_category_form() is deprecated. Use \core_question\bank\search\category_condition
384
 
385
    protected function display_category_form_checkbox deprecated use html_writer::checkbox and separate JavaScript
386
 
387
To add filters, local plugins can now implement the function local_[pluginname]_get_question_bank_search_conditions,
388
 
389
2) To make columns available to question_bank_view, plugins can extend core_question\bank\column_base.
390
   Users may choose to display additional columns by setting $CFG->questionbankcolumns to a comma-delimited list of columns.
391
 
392
3) The subsort separator has changed from _ to - in order to distinuguish subsorts vs frankenstyle component separators.
393
 
394
4) Because of the move to autoloading, $knowncolumntypes and known_field_types() are no longer used.
395
 
396
5) question_bank_column_base and it's derived classes have been namespaced to core_question\bank\column_base.
397
 
398
 
399
=== 2.6 ===
400
 
401
1) Modules using the question bank MUST now declare their use of it with the xxx_supports()
402
   flag FEATURE_USES_QUESTIONS. question_module_uses_questions() should be used to determine
403
   if a module uses questions.
404
 
405
2) It is sometimes necessary to display bits of question content without having
406
   and attempt (question_usage) in progress. Two examples of this are the option
407
   in the question bank to display the questiontext, and in the quiz statistics
408
   report, where it displays the question text above the report.
409
 
410
   Previously, this display was done using a special method that only worked for
411
   the question text, but which would not work for other parts of the question.
412
   That old mechanism has been deprecated, and there is a new method that you
413
   should use.
414
 
415
   To display the question, replace calls to question_rewrite_questiontext_preview_urls
416
   with calls to question_rewrite_question_preview_urls. Because the new function
417
   is more flexibile, you have to pass more arguments.
418
 
419
   To perform the necessary permission checks when the file is downloaded, you need
420
   to implement the callback [component name]_question_preview_pluginfile.
421
   (Previously you implemented [component name]_questiontext_preview_pluginfile.)
422
   quiz_statistics_question_preview_pluginfile is an example of what to do.
423
 
424
   question_send_questiontext_file has been deprecated. It is no longer necessary.
425
 
426
   To ensure you are no longer using or defining any deprecated functions,
427
   search for the regular expression:
428
   question_rewrite_questiontext_preview_urls|_questiontext_preview_pluginfile|question_send_questiontext_file
429
 
430
3) The argument list for core_question_renderer::mark_summary has changed.
431
   Please update your calls. (The most likely scenario for this is if you have
432
   overridden core_question_renderer::info in your own renderer.) You need to
433
   make a change like:
434
   - $this->mark_summary($qa, $options);
435
   + $this->mark_summary($qa, $behaviouroutput, $options);