mirror of
https://github.com/opencloud-eu/opencloud.git
synced 2026-01-24 05:51:33 -05:00
* do not use spacesContext * skip sharing tests in reva * update expected failure list * do not cleanup status codes * skip shares tests in reva * update expected failure list
271 lines
14 KiB
Gherkin
271 lines
14 KiB
Gherkin
@skipOnReva
|
|
Feature: sharing
|
|
As a user
|
|
I want to update share permissions
|
|
So that I can decide what resources can be shared with which permission
|
|
|
|
Background:
|
|
Given using OCS API version "1"
|
|
And user "Alice" has been created with default attributes and without skeleton files
|
|
|
|
@smokeTest
|
|
Scenario Outline: allow modification of reshare
|
|
Given using OCS API version "<ocs_api_version>"
|
|
And these users have been created with default attributes and without skeleton files:
|
|
| username |
|
|
| Brian |
|
|
| Carol |
|
|
And user "Alice" has created folder "/TMP"
|
|
And user "Alice" has shared folder "TMP" with user "Brian"
|
|
And user "Brian" has shared folder "/Shares/TMP" with user "Carol"
|
|
When user "Brian" updates the last share using the sharing API with
|
|
| permissions | read |
|
|
Then the OCS status code should be "<ocs_status_code>"
|
|
And the HTTP status code should be "200"
|
|
And user "Carol" should not be able to upload file "filesForUpload/textfile.txt" to "/Shares/TMP/textfile.txt"
|
|
And user "Brian" should be able to upload file "filesForUpload/textfile.txt" to "/Shares/TMP/textfile.txt"
|
|
Examples:
|
|
| ocs_api_version | ocs_status_code |
|
|
| 1 | 100 |
|
|
| 2 | 200 |
|
|
|
|
@issue-1289 @issue-7555
|
|
Scenario Outline: keep group permissions in sync when the share is renamed by the receiver and then the permissions are updated by sharer
|
|
Given using OCS API version "<ocs_api_version>"
|
|
And user "Brian" has been created with default attributes and without skeleton files
|
|
And group "grp1" has been created
|
|
And user "Brian" has been added to group "grp1"
|
|
And user "Alice" has uploaded file "filesForUpload/textfile.txt" to "/textfile0.txt"
|
|
And user "Alice" has shared file "textfile0.txt" with group "grp1"
|
|
And user "Brian" has moved file "/Shares/textfile0.txt" to "/Shares/textfile_new.txt"
|
|
When user "Alice" updates the last share using the sharing API with
|
|
| permissions | read |
|
|
Then the OCS status code should be "<ocs_status_code>"
|
|
And the HTTP status code should be "200"
|
|
And the fields of the last response to user "Alice" sharing with group "grp1" should include
|
|
| id | A_STRING |
|
|
| item_type | file |
|
|
| item_source | A_STRING |
|
|
| share_type | group |
|
|
| file_source | A_STRING |
|
|
| file_target | /Shares/textfile0.txt |
|
|
| permissions | read |
|
|
| stime | A_NUMBER |
|
|
| storage | A_STRING |
|
|
| mail_send | 0 |
|
|
| uid_owner | %username% |
|
|
| displayname_owner | %displayname% |
|
|
| mimetype | text/plain |
|
|
Examples:
|
|
| ocs_api_version | ocs_status_code |
|
|
| 1 | 100 |
|
|
| 2 | 200 |
|
|
|
|
|
|
Scenario Outline: cannot set permissions to zero
|
|
Given using OCS API version "<ocs_api_version>"
|
|
And group "grp1" has been created
|
|
And user "Alice" has created folder "/FOLDER"
|
|
And user "Alice" has shared folder "/FOLDER" with group "grp1"
|
|
When user "Alice" updates the last share using the sharing API with
|
|
| permissions | 0 |
|
|
Then the OCS status code should be "400"
|
|
And the HTTP status code should be "<http_status_code>"
|
|
Examples:
|
|
| ocs_api_version | http_status_code |
|
|
| 1 | 200 |
|
|
| 2 | 400 |
|
|
|
|
@issue-2173
|
|
Scenario Outline: cannot update a share of a file with a user to have only create and/or delete permission
|
|
Given using OCS API version "<ocs_api_version>"
|
|
And user "Brian" has been created with default attributes and without skeleton files
|
|
And user "Alice" has uploaded file "filesForUpload/textfile.txt" to "/textfile0.txt"
|
|
And user "Alice" has shared file "textfile0.txt" with user "Brian"
|
|
When user "Alice" updates the last share using the sharing API with
|
|
| permissions | <permissions> |
|
|
Then the OCS status code should be "400"
|
|
And the HTTP status code should be "<http_status_code>"
|
|
# Brian should still have at least read access to the shared file
|
|
And as "Brian" entry "/Shares/textfile0.txt" should exist
|
|
Examples:
|
|
| ocs_api_version | http_status_code | permissions |
|
|
| 1 | 200 | create |
|
|
| 2 | 400 | create |
|
|
| 1 | 200 | delete |
|
|
| 2 | 400 | delete |
|
|
| 1 | 200 | create,delete |
|
|
| 2 | 400 | create,delete |
|
|
|
|
@issue-2173
|
|
Scenario Outline: cannot update a share of a file with a group to have only create and/or delete permission
|
|
Given using OCS API version "<ocs_api_version>"
|
|
And user "Brian" has been created with default attributes and without skeleton files
|
|
And group "grp1" has been created
|
|
And user "Brian" has been added to group "grp1"
|
|
And user "Alice" has uploaded file "filesForUpload/textfile.txt" to "/textfile0.txt"
|
|
And user "Alice" has shared file "textfile0.txt" with group "grp1"
|
|
When user "Alice" updates the last share using the sharing API with
|
|
| permissions | <permissions> |
|
|
Then the OCS status code should be "400"
|
|
And the HTTP status code should be "<http_status_code>"
|
|
# Brian in grp1 should still have at least read access to the shared file
|
|
And as "Brian" entry "/Shares/textfile0.txt" should exist
|
|
Examples:
|
|
| ocs_api_version | http_status_code | permissions |
|
|
| 1 | 200 | create |
|
|
| 2 | 400 | create |
|
|
| 1 | 200 | delete |
|
|
| 2 | 400 | delete |
|
|
| 1 | 200 | create,delete |
|
|
| 2 | 400 | create,delete |
|
|
|
|
@issue-2201
|
|
Scenario: share ownership change after moving a shared file outside of an outer share
|
|
Given these users have been created with default attributes and without skeleton files:
|
|
| username |
|
|
| Brian |
|
|
| Carol |
|
|
And user "Alice" has created folder "/folder1"
|
|
And user "Alice" has created folder "/folder1/folder2"
|
|
And user "Brian" has created folder "/moved-out"
|
|
And user "Alice" has shared folder "/folder1" with user "Brian" with permissions "all"
|
|
And user "Brian" has shared folder "/Shares/folder1/folder2" with user "Carol" with permissions "all"
|
|
When user "Brian" moves folder "/Shares/folder1/folder2" to "/moved-out/folder2" using the WebDAV API
|
|
Then the HTTP status code should be "201"
|
|
And the response when user "Brian" gets the info of the last share should include
|
|
| id | A_STRING |
|
|
| item_type | folder |
|
|
| item_source | A_STRING |
|
|
| share_type | user |
|
|
| file_source | A_STRING |
|
|
| file_target | /Shares/folder2 |
|
|
| permissions | all |
|
|
| stime | A_NUMBER |
|
|
| storage | A_STRING |
|
|
| mail_send | 0 |
|
|
| uid_owner | %username% |
|
|
| displayname_owner | %displayname% |
|
|
| mimetype | httpd/unix-directory |
|
|
And as "Alice" folder "/Shares/folder1/folder2" should not exist
|
|
And as "Carol" folder "/Shares/folder2" should exist
|
|
|
|
@issue-2442
|
|
Scenario: share ownership change after moving a shared file to another share
|
|
Given these users have been created with default attributes and without skeleton files:
|
|
| username |
|
|
| Brian |
|
|
| Carol |
|
|
And user "Alice" has created folder "/Alice-folder"
|
|
And user "Alice" has created folder "/Alice-folder/folder2"
|
|
And user "Carol" has created folder "/Carol-folder"
|
|
And user "Alice" has shared folder "/Alice-folder" with user "Brian" with permissions "all"
|
|
And user "Carol" has shared folder "/Carol-folder" with user "Brian" with permissions "all"
|
|
When user "Brian" moves folder "/Shares/Alice-folder/folder2" to "/Shares/Carol-folder/folder2" using the WebDAV API
|
|
Then the HTTP status code should be "201"
|
|
And the response when user "Carol" gets the info of the last share should include
|
|
| id | A_STRING |
|
|
| item_type | folder |
|
|
| item_source | A_STRING |
|
|
| share_type | user |
|
|
| file_source | A_STRING |
|
|
| file_target | /Carol-folder |
|
|
| permissions | all |
|
|
| stime | A_NUMBER |
|
|
| storage | A_STRING |
|
|
| mail_send | 0 |
|
|
| uid_owner | %username% |
|
|
| displayname_owner | %displayname% |
|
|
| mimetype | httpd/unix-directory |
|
|
And as "Alice" folder "/Alice-folder/folder2" should not exist
|
|
And as "Carol" folder "/Carol-folder/folder2" should exist
|
|
|
|
@issue-1253 @issue-1224 @issue-1225
|
|
#after fixing all the issues merge this scenario with the one below
|
|
Scenario Outline: change the permission of the share and check the API response
|
|
Given using OCS API version "<ocs_api_version>"
|
|
And user "Brian" has been created with default attributes and without skeleton files
|
|
And user "Alice" has created folder "/Alice-folder"
|
|
And user "Alice" has shared folder "/Alice-folder" with user "Brian" with permissions "read"
|
|
When user "Alice" updates the last share using the sharing API with
|
|
| permissions | all |
|
|
Then the OCS status code should be "<ocs_status_code>"
|
|
And the OCS status message should be ""
|
|
And the HTTP status code should be "200"
|
|
And the fields of the last response to user "Alice" sharing with user "Brian" should include
|
|
| id | A_STRING |
|
|
| share_type | user |
|
|
| uid_owner | %username% |
|
|
| displayname_owner | %displayname% |
|
|
| permissions | all |
|
|
| stime | A_NUMBER |
|
|
| parent | |
|
|
| expiration | |
|
|
| token | |
|
|
| uid_file_owner | %username% |
|
|
| displayname_file_owner | %displayname% |
|
|
| additional_info_owner | |
|
|
| additional_info_file_owner | |
|
|
| item_type | folder |
|
|
| item_source | A_STRING |
|
|
| path | /Alice-folder |
|
|
| mimetype | httpd/unix-directory |
|
|
| storage_id | A_STRING |
|
|
| storage | A_STRING |
|
|
| file_source | A_STRING |
|
|
| file_target | /Shares/Alice-folder |
|
|
| share_with | %username% |
|
|
| share_with_displayname | %displayname% |
|
|
| share_with_additional_info | |
|
|
| mail_send | 0 |
|
|
| attributes | |
|
|
And the fields of the last response should not include
|
|
| name | |
|
|
# | token | |
|
|
Examples:
|
|
| ocs_api_version | ocs_status_code |
|
|
| 1 | 100 |
|
|
| 2 | 200 |
|
|
|
|
|
|
Scenario Outline: increasing permissions is allowed for owner
|
|
Given using OCS API version "<ocs_api_version>"
|
|
And user "Brian" has been created with default attributes and without skeleton files
|
|
And user "Carol" has been created with default attributes and without skeleton files
|
|
And group "grp1" has been created
|
|
And user "Brian" has been added to group "grp1"
|
|
And user "Carol" has been added to group "grp1"
|
|
And user "Carol" has created folder "/FOLDER"
|
|
And user "Carol" has shared folder "/FOLDER" with group "grp1"
|
|
And user "Carol" has updated the last share with
|
|
| permissions | read |
|
|
When user "Carol" updates the last share using the sharing API with
|
|
| permissions | all |
|
|
Then the OCS status code should be "<ocs_status_code>"
|
|
And the HTTP status code should be "200"
|
|
And user "Brian" should be able to upload file "filesForUpload/textfile.txt" to "/Shares/FOLDER/textfile.txt"
|
|
Examples:
|
|
| ocs_api_version | ocs_status_code |
|
|
| 1 | 100 |
|
|
| 2 | 200 |
|
|
|
|
|
|
Scenario Outline: sharer deletes file uploaded with upload-only permission by sharee to a shared folder
|
|
Given using <dav-path-version> DAV path
|
|
And user "Brian" has been created with default attributes and without skeleton files
|
|
And user "Alice" has created folder "/FOLDER"
|
|
And user "Alice" has created a share with settings
|
|
| path | FOLDER |
|
|
| shareType | user |
|
|
| permissions | create |
|
|
| shareWith | Brian |
|
|
And user "Brian" has uploaded file with content "some content" to "/Shares/FOLDER/textFile.txt"
|
|
When user "Alice" deletes file "/FOLDER/textFile.txt" using the WebDAV API
|
|
Then the HTTP status code should be "204"
|
|
And as "Brian" file "/Shares/FOLDER/textFile.txt" should not exist
|
|
And as "Alice" file "/textFile.txt" should not exist
|
|
Examples:
|
|
| dav-path-version |
|
|
| old |
|
|
| new |
|