You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
215 lines
11 KiB
215 lines
11 KiB
@core @core_user
|
|
Feature: Custom profile fields should be visible and editable by those with the correct permissions.
|
|
|
|
Background:
|
|
Given the following "users" exist:
|
|
| username | firstname | lastname | email |
|
|
| userwithinformation | userwithinformation | 1 | userwithinformation@example.com |
|
|
And the following "courses" exist:
|
|
| fullname | shortname | category | groupmode |
|
|
| Course 1 | C1 | 0 | 1 |
|
|
And the following "course enrolments" exist:
|
|
| user | course | role |
|
|
| userwithinformation | C1 | student |
|
|
|
|
And the following config values are set as admin:
|
|
| registerauth | email |
|
|
|
|
And I log in as "admin"
|
|
And I navigate to "Users > Accounts > User profile fields" in site administration
|
|
And I set the field "datatype" to "Text input"
|
|
And I set the following fields to these values:
|
|
| Short name | notvisible_field |
|
|
| Name | notvisible_field |
|
|
| Display on signup page? | Yes |
|
|
| Who is this field visible to? | Not visible |
|
|
And I click on "Save changes" "button"
|
|
|
|
And I set the field "datatype" to "Text input"
|
|
And I set the following fields to these values:
|
|
| Short name | uservisible_field |
|
|
| Name | uservisible_field |
|
|
| Display on signup page? | Yes |
|
|
| Who is this field visible to? | Visible to user |
|
|
And I click on "Save changes" "button"
|
|
|
|
And I set the field "datatype" to "Text input"
|
|
And I set the following fields to these values:
|
|
| Short name | everyonevisible_field |
|
|
| Name | everyonevisible_field |
|
|
| Display on signup page? | No |
|
|
| Who is this field visible to? | Visible to everyone |
|
|
And I click on "Save changes" "button"
|
|
|
|
And I navigate to "Users > Accounts > Browse list of users" in site administration
|
|
And I click on ".icon[title=Edit]" "css_element" in the "userwithinformation@example.com" "table_row"
|
|
And I expand all fieldsets
|
|
And I set the field "notvisible_field" to "notvisible_field_information"
|
|
And I set the field "uservisible_field" to "uservisible_field_information"
|
|
And I set the field "everyonevisible_field" to "everyonevisible_field_information"
|
|
And I click on "Update profile" "button"
|
|
And I log out
|
|
|
|
@javascript
|
|
Scenario: Visible custom profile fields can be part of the sign up form for anonymous users.
|
|
Given I am on site homepage
|
|
And I follow "Log in"
|
|
When I press "Create new account"
|
|
And I expand all fieldsets
|
|
Then I should not see "notvisible_field"
|
|
And I should see "uservisible_field"
|
|
And I should not see "everyonevisible_field"
|
|
|
|
@javascript
|
|
Scenario: Visible custom profile fields can be part of the sign up form for guest users.
|
|
Given I log in as "guest"
|
|
And I am on site homepage
|
|
And I follow "Log in"
|
|
When I press "Create new account"
|
|
And I expand all fieldsets
|
|
Then I should not see "notvisible_field"
|
|
And I should see "uservisible_field"
|
|
And I should not see "everyonevisible_field"
|
|
|
|
@javascript
|
|
Scenario: User with moodle/user:update but without moodle/user:viewalldetails can only update visible profile fields.
|
|
Given the following "roles" exist:
|
|
| name | shortname | description | archetype |
|
|
| Update Users | updateusers | updateusers | |
|
|
And the following "permission overrides" exist:
|
|
| capability | permission | role | contextlevel | reference |
|
|
| moodle/user:update | Allow | updateusers | System | |
|
|
And the following "users" exist:
|
|
| username | firstname | lastname | email |
|
|
| user_updateusers | updateusers | 1 | updateusers@example.com |
|
|
And the following "role assigns" exist:
|
|
| user | role | contextlevel | reference |
|
|
| user_updateusers | updateusers | System | |
|
|
And the following "course enrolments" exist:
|
|
| user | course | role |
|
|
| user_updateusers | C1 | editingteacher |
|
|
And I log in as "user_updateusers"
|
|
And I am on "Course 1" course homepage
|
|
And I navigate to course participants
|
|
And I follow "userwithinformation 1"
|
|
|
|
Then I should see "everyonevisible_field"
|
|
And I should see "everyonevisible_field_information"
|
|
And I should not see "uservisible_field"
|
|
And I should not see "uservisible_field_information"
|
|
And I should not see "notvisible_field"
|
|
And I should not see "notvisible_field_information"
|
|
And I follow "Edit profile"
|
|
And the following fields match these values:
|
|
| everyonevisible_field | everyonevisible_field_information |
|
|
And I should not see "uservisible_field"
|
|
And I should not see "notvisible_field"
|
|
|
|
@javascript
|
|
Scenario: User with moodle/user:viewalldetails but without moodle/user:update can view all profile fields.
|
|
Given the following "roles" exist:
|
|
| name | shortname | description | archetype |
|
|
| View All Details | viewalldetails | viewalldetails | |
|
|
And the following "permission overrides" exist:
|
|
| capability | permission | role | contextlevel | reference |
|
|
| moodle/user:viewalldetails | Allow | viewalldetails | System | |
|
|
And the following "users" exist:
|
|
| username | firstname | lastname | email |
|
|
| user_viewalldetails | viewalldetails | 1 | viewalldetails@example.com |
|
|
And the following "role assigns" exist:
|
|
| user | role | contextlevel | reference |
|
|
| user_viewalldetails | viewalldetails | System | |
|
|
And the following "course enrolments" exist:
|
|
| user | course | role |
|
|
| user_viewalldetails | C1 | editingteacher |
|
|
And I log in as "user_viewalldetails"
|
|
And I am on "Course 1" course homepage
|
|
And I navigate to course participants
|
|
And I follow "userwithinformation 1"
|
|
|
|
Then I should see "everyonevisible_field"
|
|
And I should see "everyonevisible_field_information"
|
|
And I should see "uservisible_field"
|
|
And I should see "uservisible_field_information"
|
|
And I should see "notvisible_field"
|
|
And I should see "notvisible_field_information"
|
|
And I should not see "Edit profile"
|
|
|
|
@javascript
|
|
Scenario: User with moodle/user:viewalldetails and moodle/user:update capabilities can view and edit all profile fields.
|
|
Given the following "roles" exist:
|
|
| name | shortname | description | archetype |
|
|
| View All Details and Update Users | viewalldetailsandupdateusers | viewalldetailsandupdateusers | |
|
|
And the following "permission overrides" exist:
|
|
| capability | permission | role | contextlevel | reference |
|
|
| moodle/user:viewalldetails | Allow | viewalldetailsandupdateusers | System | |
|
|
| moodle/user:update | Allow | viewalldetailsandupdateusers | System | |
|
|
And the following "users" exist:
|
|
| username | firstname | lastname | email |
|
|
| user_viewalldetailsandupdateusers | viewalldetailsandupdateusers | 1 | viewalldetailsandupdateusers@example.com |
|
|
And the following "role assigns" exist:
|
|
| user | role | contextlevel | reference |
|
|
| user_viewalldetailsandupdateusers | viewalldetailsandupdateusers | System | |
|
|
And the following "course enrolments" exist:
|
|
| user | course | role |
|
|
| user_viewalldetailsandupdateusers | C1 | editingteacher |
|
|
And I log in as "user_viewalldetailsandupdateusers"
|
|
And I am on "Course 1" course homepage
|
|
And I navigate to course participants
|
|
And I follow "userwithinformation 1"
|
|
|
|
Then I should see "everyonevisible_field"
|
|
And I should see "everyonevisible_field_information"
|
|
And I should see "uservisible_field"
|
|
And I should see "uservisible_field_information"
|
|
And I should see "notvisible_field"
|
|
And I should see "notvisible_field_information"
|
|
And I follow "Edit profile"
|
|
And the following fields match these values:
|
|
| everyonevisible_field | everyonevisible_field_information |
|
|
| uservisible_field | uservisible_field_information |
|
|
| notvisible_field | notvisible_field_information |
|
|
|
|
@javascript
|
|
Scenario: Users can view and edit custom profile fields except those marked as not visible.
|
|
Given I log in as "userwithinformation"
|
|
And I follow "Profile" in the user menu
|
|
|
|
Then I should see "everyonevisible_field"
|
|
And I should see "everyonevisible_field_information"
|
|
And I should see "uservisible_field"
|
|
And I should see "uservisible_field_information"
|
|
And I should not see "notvisible_field"
|
|
And I should not see "notvisible_field_information"
|
|
|
|
And I click on "Edit profile" "link" in the "region-main" "region"
|
|
Then the following fields match these values:
|
|
| everyonevisible_field | everyonevisible_field_information |
|
|
| uservisible_field | uservisible_field_information |
|
|
And I should not see "notvisible_field"
|
|
And I should not see "notvisible_field_information"
|
|
|
|
@javascript
|
|
Scenario: Users can view but not edit custom profile fields when denied the edit own profile capability.
|
|
Given the following "roles" exist:
|
|
| name | shortname | description | archetype |
|
|
| Deny editownprofile | denyeditownprofile | denyeditownprofile | |
|
|
|
|
And the following "permission overrides" exist:
|
|
| capability | permission | role | contextlevel | reference |
|
|
| moodle/user:editownprofile | Prohibit | denyeditownprofile | System | |
|
|
And the following "role assigns" exist:
|
|
| user | role | contextlevel | reference |
|
|
| userwithinformation | denyeditownprofile | System | |
|
|
|
|
And I log in as "userwithinformation"
|
|
And I follow "Profile" in the user menu
|
|
|
|
Then I should see "everyonevisible_field"
|
|
And I should see "everyonevisible_field_information"
|
|
And I should see "uservisible_field"
|
|
And I should see "uservisible_field_information"
|
|
And I should not see "notvisible_field"
|
|
And I should not see "notvisible_field_information"
|
|
|
|
And I should not see "Edit profile"
|