mirror of
https://github.com/moodle/moodle.git
synced 2025-02-19 07:41:02 +01:00
Fixed submission grade aggregation
Overriding the submission grade influence the total grade, not the aggregated one.
This commit is contained in:
parent
43b34576a4
commit
1696f36cf2
@ -1216,7 +1216,7 @@ class workshop {
|
||||
global $DB;
|
||||
|
||||
// fetch a recordset with all assessments to process
|
||||
$sql = 'SELECT s.id AS submissionid, s.grade AS submissiongrade, s.gradeover,
|
||||
$sql = 'SELECT s.id AS submissionid, s.grade AS submissiongrade,
|
||||
a.weight, a.grade
|
||||
FROM {workshop_submissions} s
|
||||
LEFT JOIN {workshop_assessments} a ON (a.submissionid = s.id)
|
||||
@ -1412,11 +1412,6 @@ class workshop {
|
||||
// the currently saved grade is the same in all records, fetch it during the first loop cycle
|
||||
$current = $assessment->submissiongrade;
|
||||
}
|
||||
if (!is_null($assessment->gradeover)) {
|
||||
// the grade for this assessment is overriden by a teacher, no need to calculate anything
|
||||
$finalgrade = grade_floatval($assessment->gradeover);
|
||||
break;
|
||||
}
|
||||
if (is_null($assessment->grade)) {
|
||||
// this was not assessed yet
|
||||
continue;
|
||||
|
@ -83,8 +83,7 @@ class workshop_internal_api_test extends UnitTestCase {
|
||||
|
||||
// fixture set-up
|
||||
$batch = array(); // batch of a submission's assessments
|
||||
$batch[] = (object)array('submissionid' => 12, 'submissiongrade' => null, 'gradeover' => null, 'weight' => 1,
|
||||
'grade' => null);
|
||||
$batch[] = (object)array('submissionid' => 12, 'submissiongrade' => null, 'weight' => 1, 'grade' => null);
|
||||
$DB->expectNever('set_field');
|
||||
// excercise SUT
|
||||
$this->workshop->aggregate_submission_grades_process($batch);
|
||||
@ -95,8 +94,7 @@ class workshop_internal_api_test extends UnitTestCase {
|
||||
|
||||
// fixture set-up
|
||||
$batch = array(); // batch of a submission's assessments
|
||||
$batch[] = (object)array('submissionid' => 12, 'submissiongrade' => null, 'gradeover' => null, 'weight' => 1,
|
||||
'grade' => 10.12345);
|
||||
$batch[] = (object)array('submissionid' => 12, 'submissiongrade' => null, 'weight' => 1, 'grade' => 10.12345);
|
||||
$expected = 10.12345;
|
||||
$DB->expectOnce('set_field', array('workshop_submissions', 'grade', $expected, array('id' => 12)));
|
||||
// excercise SUT
|
||||
@ -108,10 +106,8 @@ class workshop_internal_api_test extends UnitTestCase {
|
||||
|
||||
// fixture set-up
|
||||
$batch = array(); // batch of a submission's assessments
|
||||
$batch[] = (object)array('submissionid' => 12, 'submissiongrade' => null, 'gradeover' => null, 'weight' => 1,
|
||||
'grade' => 45.54321);
|
||||
$batch[] = (object)array('submissionid' => 12, 'submissiongrade' => null, 'gradeover' => null, 'weight' => 1,
|
||||
'grade' => null);
|
||||
$batch[] = (object)array('submissionid' => 12, 'submissiongrade' => null, 'weight' => 1, 'grade' => 45.54321);
|
||||
$batch[] = (object)array('submissionid' => 12, 'submissiongrade' => null, 'weight' => 1, 'grade' => null);
|
||||
$expected = 45.54321;
|
||||
$DB->expectOnce('set_field', array('workshop_submissions', 'grade', $expected, array('id' => 12)));
|
||||
// excercise SUT
|
||||
@ -123,8 +119,7 @@ class workshop_internal_api_test extends UnitTestCase {
|
||||
|
||||
// fixture set-up
|
||||
$batch = array(); // batch of a submission's assessments
|
||||
$batch[] = (object)array('submissionid' => 12, 'submissiongrade' => null, 'gradeover' => null,
|
||||
'weight' => 4, 'grade' => 14.00012);
|
||||
$batch[] = (object)array('submissionid' => 12, 'submissiongrade' => null, 'weight' => 4, 'grade' => 14.00012);
|
||||
$expected = 14.00012;
|
||||
$DB->expectOnce('set_field', array('workshop_submissions', 'grade', $expected, array('id' => 12)));
|
||||
// excercise SUT
|
||||
@ -136,14 +131,10 @@ class workshop_internal_api_test extends UnitTestCase {
|
||||
|
||||
// fixture set-up
|
||||
$batch = array(); // batch of a submission's assessments
|
||||
$batch[] = (object)array('submissionid' => 45, 'submissiongrade' => null, 'gradeover' => null, 'weight' => 1,
|
||||
'grade' => 56.12000);
|
||||
$batch[] = (object)array('submissionid' => 45, 'submissiongrade' => null, 'gradeover' => null, 'weight' => 1,
|
||||
'grade' => 12.59000);
|
||||
$batch[] = (object)array('submissionid' => 45, 'submissiongrade' => null, 'gradeover' => null, 'weight' => 1,
|
||||
'grade' => 10.00000);
|
||||
$batch[] = (object)array('submissionid' => 45, 'submissiongrade' => null, 'gradeover' => null, 'weight' => 1,
|
||||
'grade' => 0.00000);
|
||||
$batch[] = (object)array('submissionid' => 45, 'submissiongrade' => null, 'weight' => 1, 'grade' => 56.12000);
|
||||
$batch[] = (object)array('submissionid' => 45, 'submissiongrade' => null, 'weight' => 1, 'grade' => 12.59000);
|
||||
$batch[] = (object)array('submissionid' => 45, 'submissiongrade' => null, 'weight' => 1, 'grade' => 10.00000);
|
||||
$batch[] = (object)array('submissionid' => 45, 'submissiongrade' => null, 'weight' => 1, 'grade' => 0.00000);
|
||||
$expected = 19.67750;
|
||||
$DB->expectOnce('set_field', array('workshop_submissions', 'grade', $expected, array('id' => 45)));
|
||||
// excercise SUT
|
||||
@ -155,14 +146,10 @@ class workshop_internal_api_test extends UnitTestCase {
|
||||
|
||||
// fixture set-up
|
||||
$batch = array(); // batch of a submission's assessments
|
||||
$batch[] = (object)array('submissionid' => 45, 'submissiongrade' => 12.57750, 'gradeover' => null, 'weight' => 1,
|
||||
'grade' => 56.12000);
|
||||
$batch[] = (object)array('submissionid' => 45, 'submissiongrade' => 12.57750, 'gradeover' => null, 'weight' => 1,
|
||||
'grade' => 12.59000);
|
||||
$batch[] = (object)array('submissionid' => 45, 'submissiongrade' => 12.57750, 'gradeover' => null, 'weight' => 1,
|
||||
'grade' => 10.00000);
|
||||
$batch[] = (object)array('submissionid' => 45, 'submissiongrade' => 12.57750, 'gradeover' => null, 'weight' => 1,
|
||||
'grade' => 0.00000);
|
||||
$batch[] = (object)array('submissionid' => 45, 'submissiongrade' => 12.57750, 'weight' => 1, 'grade' => 56.12000);
|
||||
$batch[] = (object)array('submissionid' => 45, 'submissiongrade' => 12.57750, 'weight' => 1, 'grade' => 12.59000);
|
||||
$batch[] = (object)array('submissionid' => 45, 'submissiongrade' => 12.57750, 'weight' => 1, 'grade' => 10.00000);
|
||||
$batch[] = (object)array('submissionid' => 45, 'submissiongrade' => 12.57750, 'weight' => 1, 'grade' => 0.00000);
|
||||
$expected = 19.67750;
|
||||
$DB->expectOnce('set_field', array('workshop_submissions', 'grade', $expected, array('id' => 45)));
|
||||
// excercise SUT
|
||||
@ -174,14 +161,10 @@ class workshop_internal_api_test extends UnitTestCase {
|
||||
|
||||
// fixture set-up
|
||||
$batch = array(); // batch of a submission's assessments
|
||||
$batch[] = (object)array('submissionid' => 45, 'submissiongrade' => 19.67750, 'gradeover' => null, 'weight' => 1,
|
||||
'grade' => 56.12000);
|
||||
$batch[] = (object)array('submissionid' => 45, 'submissiongrade' => 19.67750, 'gradeover' => null, 'weight' => 1,
|
||||
'grade' => 12.59000);
|
||||
$batch[] = (object)array('submissionid' => 45, 'submissiongrade' => 19.67750, 'gradeover' => null, 'weight' => 1,
|
||||
'grade' => 10.00000);
|
||||
$batch[] = (object)array('submissionid' => 45, 'submissiongrade' => 19.67750, 'gradeover' => null, 'weight' => 1,
|
||||
'grade' => 0.00000);
|
||||
$batch[] = (object)array('submissionid' => 45, 'submissiongrade' => 19.67750, 'weight' => 1, 'grade' => 56.12000);
|
||||
$batch[] = (object)array('submissionid' => 45, 'submissiongrade' => 19.67750, 'weight' => 1, 'grade' => 12.59000);
|
||||
$batch[] = (object)array('submissionid' => 45, 'submissiongrade' => 19.67750, 'weight' => 1, 'grade' => 10.00000);
|
||||
$batch[] = (object)array('submissionid' => 45, 'submissiongrade' => 19.67750, 'weight' => 1, 'grade' => 0.00000);
|
||||
$DB->expectNever('set_field');
|
||||
// excercise SUT
|
||||
$this->workshop->aggregate_submission_grades_process($batch);
|
||||
@ -192,12 +175,9 @@ class workshop_internal_api_test extends UnitTestCase {
|
||||
|
||||
// fixture set-up
|
||||
$batch = array(); // batch of a submission's assessments
|
||||
$batch[] = (object)array('submissionid' => 45, 'submissiongrade' => null, 'gradeover' => null, 'weight' => 1,
|
||||
'grade' => 4.00000);
|
||||
$batch[] = (object)array('submissionid' => 45, 'submissiongrade' => null, 'gradeover' => null, 'weight' => 1,
|
||||
'grade' => 2.00000);
|
||||
$batch[] = (object)array('submissionid' => 45, 'submissiongrade' => null, 'gradeover' => null, 'weight' => 1,
|
||||
'grade' => 1.00000);
|
||||
$batch[] = (object)array('submissionid' => 45, 'submissiongrade' => null, 'weight' => 1, 'grade' => 4.00000);
|
||||
$batch[] = (object)array('submissionid' => 45, 'submissiongrade' => null, 'weight' => 1, 'grade' => 2.00000);
|
||||
$batch[] = (object)array('submissionid' => 45, 'submissiongrade' => null, 'weight' => 1, 'grade' => 1.00000);
|
||||
$expected = 2.33333;
|
||||
$DB->expectOnce('set_field', array('workshop_submissions', 'grade', $expected, array('id' => 45)));
|
||||
// excercise SUT
|
||||
@ -209,49 +189,16 @@ class workshop_internal_api_test extends UnitTestCase {
|
||||
|
||||
// fixture set-up
|
||||
$batch = array(); // batch of a submission's assessments
|
||||
$batch[] = (object)array('submissionid' => 45, 'submissiongrade' => null, 'gradeover' => null,
|
||||
'weight' => 3, 'grade' => 12.00000);
|
||||
$batch[] = (object)array('submissionid' => 45, 'submissiongrade' => null, 'gradeover' => null,
|
||||
'weight' => 2, 'grade' => 30.00000);
|
||||
$batch[] = (object)array('submissionid' => 45, 'submissiongrade' => null, 'gradeover' => null,
|
||||
'weight' => 1, 'grade' => 10.00000);
|
||||
$batch[] = (object)array('submissionid' => 45, 'submissiongrade' => null, 'gradeover' => null,
|
||||
'weight' => 0, 'grade' => 1000.00000);
|
||||
$batch[] = (object)array('submissionid' => 45, 'submissiongrade' => null, 'weight' => 3, 'grade' => 12.00000);
|
||||
$batch[] = (object)array('submissionid' => 45, 'submissiongrade' => null, 'weight' => 2, 'grade' => 30.00000);
|
||||
$batch[] = (object)array('submissionid' => 45, 'submissiongrade' => null, 'weight' => 1, 'grade' => 10.00000);
|
||||
$batch[] = (object)array('submissionid' => 45, 'submissiongrade' => null, 'weight' => 0, 'grade' => 1000.00000);
|
||||
$expected = 17.66667;
|
||||
$DB->expectOnce('set_field', array('workshop_submissions', 'grade', $expected, array('id' => 45)));
|
||||
// excercise SUT
|
||||
$this->workshop->aggregate_submission_grades_process($batch);
|
||||
}
|
||||
|
||||
public function test_aggregate_submission_grades_process_overriden_different() {
|
||||
global $DB;
|
||||
|
||||
// fixture set-up
|
||||
$batch = array(); // batch of a submission's assessments
|
||||
$batch[] = (object)array('submissionid' => 11, 'submissiongrade' => null, 'gradeover' => 95.00000,
|
||||
'weight' => 3, 'grade' => 100.00000);
|
||||
$batch[] = (object)array('submissionid' => 11, 'submissiongrade' => null, 'gradeover' => 95.00000,
|
||||
'weight' => 2, 'grade' => 96.50000);
|
||||
$expected = 95.00000;
|
||||
$DB->expectOnce('set_field', array('workshop_submissions', 'grade', $expected, array('id' => 11)));
|
||||
// excercise SUT
|
||||
$this->workshop->aggregate_submission_grades_process($batch);
|
||||
}
|
||||
|
||||
public function test_aggregate_submission_grades_process_overriden_equals() {
|
||||
global $DB;
|
||||
|
||||
// fixture set-up
|
||||
$batch = array(); // batch of a submission's assessments
|
||||
$batch[] = (object)array('submissionid' => 11, 'submissiongrade' => 95.00000, 'gradeover' => 95.00000,
|
||||
'weight' => 3, 'grade' => 100.00000);
|
||||
$batch[] = (object)array('submissionid' => 11, 'submissiongrade' => 95.00000, 'gradeover' => 95.00000,
|
||||
'weight' => 2, 'grade' => 96.50000);
|
||||
$DB->expectNever('set_field');
|
||||
// excercise SUT
|
||||
$this->workshop->aggregate_submission_grades_process($batch);
|
||||
}
|
||||
|
||||
public function test_aggregate_grading_grades_process_nograding() {
|
||||
global $DB;
|
||||
// fixture set-up
|
||||
|
Loading…
x
Reference in New Issue
Block a user