* This means the submission modification time is more recent than the
* grading modification time and the status is SUBMITTED.
*
+ * @param mixed $currentgroup int|null the group for counting (if null the function will determine it)
* @return int number of matching submissions
*/
- public function count_submissions_need_grading() {
+ public function count_submissions_need_grading($currentgroup = null) {
global $DB;
if ($this->get_instance()->teamsubmission) {
return 0;
}
- $currentgroup = groups_get_activity_group($this->get_course_module(), true);
+ if ($currentgroup === null) {
+ $currentgroup = groups_get_activity_group($this->get_course_module(), true);
+ }
list($esql, $params) = get_enrolled_sql($this->get_context(), 'mod/assign:submit', $currentgroup, true);
$params['assignid'] = $this->get_instance()->id;
* Load a count of submissions with a specified status.
*
* @param string $status The submission status - should match one of the constants
+ * @param mixed $currentgroup int|null the group for counting (if null the function will determine it)
* @return int number of matching submissions
*/
- public function count_submissions_with_status($status) {
+ public function count_submissions_with_status($status, $currentgroup = null) {
global $DB;
- $currentgroup = groups_get_activity_group($this->get_course_module(), true);
+ if ($currentgroup === null) {
+ $currentgroup = groups_get_activity_group($this->get_course_module(), true);
+ }
list($esql, $params) = get_enrolled_sql($this->get_context(), 'mod/assign:submit', $currentgroup, true);
$params['assignid'] = $this->get_instance()->id;
$summary = new assign_grading_summary($this->count_teams($activitygroup),
$instance->submissiondrafts,
- $this->count_submissions_with_status($draft),
+ $this->count_submissions_with_status($draft, $activitygroup),
$this->is_any_submission_plugin_enabled(),
- $this->count_submissions_with_status($submitted),
+ $this->count_submissions_with_status($submitted, $activitygroup),
$instance->cutoffdate,
$instance->duedate,
$this->get_course_module()->id,
- $this->count_submissions_need_grading(),
+ $this->count_submissions_need_grading($activitygroup),
$instance->teamsubmission,
$warnofungroupedusers,
$this->can_grade());
$countparticipants = $this->count_participants($activitygroup);
$summary = new assign_grading_summary($countparticipants,
$instance->submissiondrafts,
- $this->count_submissions_with_status($draft),
+ $this->count_submissions_with_status($draft, $activitygroup),
$this->is_any_submission_plugin_enabled(),
- $this->count_submissions_with_status($submitted),
+ $this->count_submissions_with_status($submitted, $activitygroup),
$instance->cutoffdate,
$instance->duedate,
$this->get_course_module()->id,
- $this->count_submissions_need_grading(),
+ $this->count_submissions_need_grading($activitygroup),
$instance->teamsubmission,
false,
$this->can_grade());
$this->assertEquals(1, $result['gradingsummary']['participantcount']);
$this->assertEquals(0, $result['gradingsummary']['submissiondraftscount']);
$this->assertEquals(1, $result['gradingsummary']['submissionsenabled']);
- $this->assertEquals(1, $result['gradingsummary']['submissionssubmittedcount']);
- $this->assertEquals(1, $result['gradingsummary']['submissionsneedgradingcount']);
+ $this->assertEquals(0, $result['gradingsummary']['submissiondraftscount']);
+ $this->assertEquals(1, $result['gradingsummary']['submissionssubmittedcount']); // One student from G1 submitted.
+ $this->assertEquals(1, $result['gradingsummary']['submissionsneedgradingcount']); // One student from G1 submitted.
$this->assertFalse($result['gradingsummary']['warnofungroupedusers']);
// Second group.
$result = external_api::clean_returnvalue(mod_assign_external::get_submission_status_returns(), $result);
$this->assertCount(0, $result['warnings']);
$this->assertEquals(1, $result['gradingsummary']['participantcount']);
+ $this->assertEquals(0, $result['gradingsummary']['submissionssubmittedcount']); // G2 students didn't submit yet.
+ $this->assertEquals(0, $result['gradingsummary']['submissionsneedgradingcount']); // G2 students didn't submit yet.
// Should return also 1 participant if we allow the function to auto-select the group.
$result = mod_assign_external::get_submission_status($assign->get_instance()->id);
$result = external_api::clean_returnvalue(mod_assign_external::get_submission_status_returns(), $result);
$this->assertCount(0, $result['warnings']);
$this->assertEquals(1, $result['gradingsummary']['participantcount']);
+ $this->assertEquals(0, $result['gradingsummary']['submissiondraftscount']);
+ $this->assertEquals(1, $result['gradingsummary']['submissionssubmittedcount']); // One student from G1 submitted.
+ $this->assertEquals(1, $result['gradingsummary']['submissionsneedgradingcount']); // One student from G1 submitted.
+
+ // Now check draft submissions.
+ list($assign, $instance, $student1, $student2, $teacher, $g1, $g2) = $this->create_submission_for_testing_status(false);
+ $this->setUser($teacher);
+ $result = mod_assign_external::get_submission_status($assign->get_instance()->id, 0, $g1->id);
+ $result = external_api::clean_returnvalue(mod_assign_external::get_submission_status_returns(), $result);
+ $this->assertCount(0, $result['warnings']);
+ $this->assertEquals(1, $result['gradingsummary']['participantcount']);
+ $this->assertEquals(1, $result['gradingsummary']['submissiondraftscount']); // We have a draft submission.
+ $this->assertEquals(0, $result['gradingsummary']['submissionssubmittedcount']); // We have only draft submissions.
+ $this->assertEquals(0, $result['gradingsummary']['submissionsneedgradingcount']); // We have only draft submissions.
}
/**