Skip to content

Commit

Permalink
MDL-40241 core_completion: Minor fixes to provided patch
Browse files Browse the repository at this point in the history
Thanks to Aaron Barnes and Jon Sharp for working on this issue.
  • Loading branch information
David Monllao committed Dec 1, 2014
1 parent 525d6ce commit 95d1a36
Show file tree
Hide file tree
Showing 5 changed files with 51 additions and 59 deletions.
10 changes: 5 additions & 5 deletions completion/tests/behat/behat_completion.php
Original file line number Diff line number Diff line change
Expand Up @@ -106,18 +106,18 @@ public function go_to_the_current_course_activity_completion_report() {
}

/**
* Toggles completion tracking for course
* Toggles completion tracking for course being in the course page.
*
* @When /^completion tracking is "(?P<completion_status_string>([Ee]nabled|[Dd]isabled)*)" in current course$/
* @param string $completionstatus
* @When /^completion tracking is "(?P<completion_status_string>Enabled|Disabled)" in current course$/
* @param string $completionstatus The status, enabled or disabled.
*/
public function completion_is_toggled_in_course($completionstatus) {

$toggle = strtolower($completionstatus) == 'enabled' ? 'Yes' : 'No';
$toggle = strtolower($completionstatus) == 'enabled' ? get_string('yes') : get_string('no');

return array(
new Given('I follow "'.get_string('editsettings').'"'),
new Given('I select "'.$toggle.'" from "'.get_string('enablecompletion', 'completion').'"'),
new Given('I set the field "'.get_string('enablecompletion', 'completion').'" to "'.$toggle.'"'),
new Given('I press "'.get_string('savechanges').'"')
);
}
Expand Down
84 changes: 42 additions & 42 deletions completion/tests/behat/teacher_manual_completion.feature
Original file line number Diff line number Diff line change
@@ -1,45 +1,45 @@
@core @core_completion
Feature: Allow teachers to manually mark users as complete when configured
In order for teachers to mark students as complete
As a teacher
I need to be able to use the completion report mark complete functionality
In order for teachers to mark students as complete
As a teacher
I need to be able to use the completion report mark complete functionality

Scenario: Mark a student as complete using the completion report
Given the following "courses" exists:
| fullname | shortname | category |
| Completion course | CC1 | 0 |
And the following "users" exists:
| username | firstname | lastname | email |
| student1 | Student | First | student1@example.com |
| teacher1 | Teacher | First | teacher1@example.com |
And the following "course enrolments" exists:
| user | course | role |
| student1 | CC1 | student |
| teacher1 | CC1 | editingteacher |
And I log in as "admin"
And I set the following administration settings values:
| Enable completion tracking | 1 |
And I am on homepage
And I follow "Completion course"
And completion tracking is "enabled" in current course
And I follow "Course completion"
And I check "Teacher"
And I press "Save changes"
And I turn editing mode on
And I add the "Course completion status" block
And I log out
And I log in as "student1"
And I follow "Completion course"
And I should see "Status: Not yet started"
And I log out
When I log in as "teacher1"
And I follow "Completion course"
And I follow "View course report"
And I should see "Student First"
And I follow "Click to mark user complete"
And I run the cron
And I am on homepage
And I log out
Then I log in as "student1"
And I follow "Completion course"
And I should see "Status: Complete"
Scenario: Mark a student as complete using the completion report
Given the following "courses" exist:
| fullname | shortname | category |
| Completion course | CC1 | 0 |
And the following "users" exist:
| username | firstname | lastname | email |
| student1 | Student | First | student1@example.com |
| teacher1 | Teacher | First | teacher1@example.com |
And the following "course enrolments" exist:
| user | course | role |
| student1 | CC1 | student |
| teacher1 | CC1 | editingteacher |
And I log in as "admin"
And I set the following administration settings values:
| Enable completion tracking | 1 |
And I am on homepage
And I follow "Completion course"
And completion tracking is "Enabled" in current course
And I follow "Course completion"
And I set the field "Teacher" to "1"
And I press "Save changes"
And I turn editing mode on
And I add the "Course completion status" block
And I log out
And I log in as "student1"
And I follow "Completion course"
And I should see "Status: Not yet started"
And I log out
When I log in as "teacher1"
And I follow "Completion course"
And I follow "View course report"
And I should see "Student First"
And I follow "Click to mark user complete"
And I trigger cron
And I am on homepage
And I log out
Then I log in as "student1"
And I follow "Completion course"
And I should see "Status: Complete"
4 changes: 2 additions & 2 deletions course/togglecompletion.php
Original file line number Diff line number Diff line change
Expand Up @@ -34,7 +34,7 @@
$courseid = optional_param('course', 0, PARAM_INT);
$confirm = optional_param('confirm', 0, PARAM_BOOL);

// Check if we are marking a user complete via the completion report
// Check if we are marking a user complete via the completion report.
$user = optional_param('user', 0, PARAM_INT);
$rolec = optional_param('rolec', 0, PARAM_INT);

Expand All @@ -56,7 +56,7 @@

if (!$completion->is_enabled()) {
throw new moodle_exception('completionnotenabled', 'completion');
} elseif (!$completion->is_tracked_user($trackeduser)) {
} else if (!$completion->is_tracked_user($trackeduser)) {
throw new moodle_exception('nottracked', 'completion');
}

Expand Down
9 changes: 0 additions & 9 deletions lib/tests/behat/behat_general.php
Original file line number Diff line number Diff line change
Expand Up @@ -879,15 +879,6 @@ public function i_trigger_cron() {
$this->getSession()->visit($this->locate_path('/admin/cron.php'));
}

/**
* This step triggers cron like a user would do going to admin/cron.php (alias for "I trigger cron")
*
* @Given /^I run the cron$/
*/
public function i_run_the_cron() {
$this->i_trigger_cron();
}

/**
* Checks that an element and selector type exists in another element and selector type on the current page.
*
Expand Down
3 changes: 2 additions & 1 deletion report/completion/index.php
Original file line number Diff line number Diff line change
Expand Up @@ -672,7 +672,8 @@
)
);

print '<a href="'.$toggleurl->out().'" title="'.get_string('clicktomarkusercomplete', 'report_completion').'"><img src="'.$OUTPUT->pix_url('i/completion-manual-'.($is_complete ? 'y' : 'n')).
print '<a href="'.$toggleurl->out().'" title="'.get_string('clicktomarkusercomplete', 'report_completion').'">' .
'<img src="'.$OUTPUT->pix_url('i/completion-manual-'.($is_complete ? 'y' : 'n')).
'" alt="'.$describe.'" class="icon" /></a></td>';
} else {
print '<img src="'.$OUTPUT->pix_url('i/'.$completionicon).'" alt="'.$describe.'" class="icon" title="'.$fulldescribe.'" /></td>';
Expand Down

0 comments on commit 95d1a36

Please sign in to comment.