Merge pull request #4121 from nextcloud/split-sharing-integration-tests
Split long running features/sharing-v1.feature into two smaller parts
This commit is contained in:
commit
4f09dc71e0
10
.drone.yml
10
.drone.yml
|
@ -304,6 +304,15 @@ pipeline:
|
|||
when:
|
||||
matrix:
|
||||
TESTS: integration-sharing-v1
|
||||
integration-sharing-v1-part2:
|
||||
image: nextcloudci/integration-php7.0:integration-php7.0-3
|
||||
commands:
|
||||
- ./occ maintenance:install --admin-pass=admin
|
||||
- cd build/integration
|
||||
- ./run.sh features/sharing-v1-part2.feature
|
||||
when:
|
||||
matrix:
|
||||
TESTS: integration-sharing-v1-part2
|
||||
integration-checksums-v1:
|
||||
image: nextcloudci/integration-php7.0:integration-php7.0-3
|
||||
commands:
|
||||
|
@ -493,6 +502,7 @@ matrix:
|
|||
- TESTS: integration-dav-v2
|
||||
- TESTS: integration-ocs-v1
|
||||
- TESTS: integration-sharing-v1
|
||||
- TESTS: integration-sharing-v1-part2
|
||||
- TESTS: integration-checksums
|
||||
- TESTS: integration-external-storage
|
||||
- TESTS: integration-provisioning-v1
|
||||
|
|
|
@ -0,0 +1,717 @@
|
|||
Feature: sharing
|
||||
Background:
|
||||
Given using api version "1"
|
||||
Given using old dav path
|
||||
|
||||
# See sharing-v1.feature
|
||||
|
||||
Scenario: getting all shares of a file with reshares
|
||||
Given user "user0" exists
|
||||
And user "user1" exists
|
||||
And user "user2" exists
|
||||
And user "user3" exists
|
||||
And file "textfile0.txt" of user "user0" is shared with user "user1"
|
||||
And file "textfile0 (2).txt" of user "user1" is shared with user "user2"
|
||||
And As an "user0"
|
||||
When sending "GET" to "/apps/files_sharing/api/v1/shares?reshares=true&path=textfile0.txt"
|
||||
Then the OCS status code should be "100"
|
||||
And the HTTP status code should be "200"
|
||||
And User "user1" should be included in the response
|
||||
And User "user2" should be included in the response
|
||||
And User "user3" should not be included in the response
|
||||
|
||||
Scenario: Reshared files can be still accessed if a user in the middle removes it.
|
||||
Given user "user0" exists
|
||||
And user "user1" exists
|
||||
And user "user2" exists
|
||||
And user "user3" exists
|
||||
And file "textfile0.txt" of user "user0" is shared with user "user1"
|
||||
And file "textfile0 (2).txt" of user "user1" is shared with user "user2"
|
||||
And file "textfile0 (2).txt" of user "user2" is shared with user "user3"
|
||||
And As an "user1"
|
||||
When User "user1" deletes file "/textfile0 (2).txt"
|
||||
And As an "user3"
|
||||
And Downloading file "/textfile0 (2).txt" with range "bytes=1-8"
|
||||
Then Downloaded content should be "extcloud"
|
||||
|
||||
Scenario: getting share info of a share
|
||||
Given user "user0" exists
|
||||
And user "user1" exists
|
||||
And file "textfile0.txt" of user "user0" is shared with user "user1"
|
||||
And As an "user0"
|
||||
When Getting info of last share
|
||||
Then the OCS status code should be "100"
|
||||
And the HTTP status code should be "200"
|
||||
And Share fields of last share match with
|
||||
| id | A_NUMBER |
|
||||
| item_type | file |
|
||||
| item_source | A_NUMBER |
|
||||
| share_type | 0 |
|
||||
| share_with | user1 |
|
||||
| file_source | A_NUMBER |
|
||||
| file_target | /textfile0.txt |
|
||||
| path | /textfile0.txt |
|
||||
| permissions | 19 |
|
||||
| stime | A_NUMBER |
|
||||
| storage | A_NUMBER |
|
||||
| mail_send | 0 |
|
||||
| uid_owner | user0 |
|
||||
| storage_id | home::user0 |
|
||||
| file_parent | A_NUMBER |
|
||||
| share_with_displayname | user1 |
|
||||
| displayname_owner | user0 |
|
||||
| mimetype | text/plain |
|
||||
|
||||
Scenario: keep group permissions in sync
|
||||
Given As an "admin"
|
||||
Given user "user0" exists
|
||||
And user "user1" exists
|
||||
And group "group1" exists
|
||||
And user "user1" belongs to group "group1"
|
||||
And file "textfile0.txt" of user "user0" is shared with group "group1"
|
||||
And User "user1" moved file "/textfile0.txt" to "/FOLDER/textfile0.txt"
|
||||
And As an "user0"
|
||||
When Updating last share with
|
||||
| permissions | 1 |
|
||||
And Getting info of last share
|
||||
Then the OCS status code should be "100"
|
||||
And the HTTP status code should be "200"
|
||||
And Share fields of last share match with
|
||||
| id | A_NUMBER |
|
||||
| item_type | file |
|
||||
| item_source | A_NUMBER |
|
||||
| share_type | 1 |
|
||||
| file_source | A_NUMBER |
|
||||
| file_target | /textfile0.txt |
|
||||
| permissions | 1 |
|
||||
| stime | A_NUMBER |
|
||||
| storage | A_NUMBER |
|
||||
| mail_send | 0 |
|
||||
| uid_owner | user0 |
|
||||
| storage_id | home::user0 |
|
||||
| file_parent | A_NUMBER |
|
||||
| displayname_owner | user0 |
|
||||
| mimetype | text/plain |
|
||||
|
||||
Scenario: Sharee can see the share
|
||||
Given user "user0" exists
|
||||
And user "user1" exists
|
||||
And file "textfile0.txt" of user "user0" is shared with user "user1"
|
||||
And As an "user1"
|
||||
When sending "GET" to "/apps/files_sharing/api/v1/shares?shared_with_me=true"
|
||||
Then the OCS status code should be "100"
|
||||
And the HTTP status code should be "200"
|
||||
And last share_id is included in the answer
|
||||
|
||||
Scenario: Sharee can see the filtered share
|
||||
Given user "user0" exists
|
||||
And user "user1" exists
|
||||
And file "textfile0.txt" of user "user0" is shared with user "user1"
|
||||
And file "textfile1.txt" of user "user0" is shared with user "user1"
|
||||
And As an "user1"
|
||||
When sending "GET" to "/apps/files_sharing/api/v1/shares?shared_with_me=true&path=textfile1 (2).txt"
|
||||
Then the OCS status code should be "100"
|
||||
And the HTTP status code should be "200"
|
||||
And last share_id is included in the answer
|
||||
|
||||
Scenario: Sharee can't see the share that is filtered out
|
||||
Given user "user0" exists
|
||||
And user "user1" exists
|
||||
And file "textfile0.txt" of user "user0" is shared with user "user1"
|
||||
And file "textfile1.txt" of user "user0" is shared with user "user1"
|
||||
And As an "user1"
|
||||
When sending "GET" to "/apps/files_sharing/api/v1/shares?shared_with_me=true&path=textfile0 (2).txt"
|
||||
Then the OCS status code should be "100"
|
||||
And the HTTP status code should be "200"
|
||||
And last share_id is not included in the answer
|
||||
|
||||
Scenario: Sharee can see the group share
|
||||
Given As an "admin"
|
||||
And user "user0" exists
|
||||
And user "user1" exists
|
||||
And group "group0" exists
|
||||
And user "user1" belongs to group "group0"
|
||||
And file "textfile0.txt" of user "user0" is shared with group "group0"
|
||||
And As an "user1"
|
||||
When sending "GET" to "/apps/files_sharing/api/v1/shares?shared_with_me=true"
|
||||
Then the OCS status code should be "100"
|
||||
And the HTTP status code should be "200"
|
||||
And last share_id is included in the answer
|
||||
|
||||
Scenario: User is not allowed to reshare file
|
||||
As an "admin"
|
||||
Given user "user0" exists
|
||||
And user "user1" exists
|
||||
And user "user2" exists
|
||||
And As an "user0"
|
||||
And creating a share with
|
||||
| path | /textfile0.txt |
|
||||
| shareType | 0 |
|
||||
| shareWith | user1 |
|
||||
| permissions | 8 |
|
||||
And As an "user1"
|
||||
When creating a share with
|
||||
| path | /textfile0 (2).txt |
|
||||
| shareType | 0 |
|
||||
| shareWith | user2 |
|
||||
| permissions | 31 |
|
||||
Then the OCS status code should be "404"
|
||||
And the HTTP status code should be "200"
|
||||
|
||||
Scenario: User is not allowed to reshare file with more permissions
|
||||
As an "admin"
|
||||
Given user "user0" exists
|
||||
And user "user1" exists
|
||||
And user "user2" exists
|
||||
And As an "user0"
|
||||
And creating a share with
|
||||
| path | /textfile0.txt |
|
||||
| shareType | 0 |
|
||||
| shareWith | user1 |
|
||||
| permissions | 16 |
|
||||
And As an "user1"
|
||||
When creating a share with
|
||||
| path | /textfile0 (2).txt |
|
||||
| shareType | 0 |
|
||||
| shareWith | user2 |
|
||||
| permissions | 31 |
|
||||
Then the OCS status code should be "404"
|
||||
And the HTTP status code should be "200"
|
||||
|
||||
Scenario: Get a share with a user which didn't received the share
|
||||
Given user "user0" exists
|
||||
And user "user1" exists
|
||||
And user "user2" exists
|
||||
And file "textfile0.txt" of user "user0" is shared with user "user1"
|
||||
And As an "user2"
|
||||
When Getting info of last share
|
||||
Then the OCS status code should be "404"
|
||||
And the HTTP status code should be "200"
|
||||
|
||||
Scenario: Share of folder and sub-folder to same user - core#20645
|
||||
Given As an "admin"
|
||||
And user "user0" exists
|
||||
And user "user1" exists
|
||||
And group "group0" exists
|
||||
And user "user1" belongs to group "group0"
|
||||
And file "/PARENT" of user "user0" is shared with user "user1"
|
||||
When file "/PARENT/CHILD" of user "user0" is shared with group "group0"
|
||||
Then user "user1" should see following elements
|
||||
| /FOLDER/ |
|
||||
| /PARENT/ |
|
||||
| /CHILD/ |
|
||||
| /PARENT/parent.txt |
|
||||
| /CHILD/child.txt |
|
||||
And the HTTP status code should be "200"
|
||||
|
||||
Scenario: Share a file by multiple channels
|
||||
Given As an "admin"
|
||||
And user "user0" exists
|
||||
And user "user1" exists
|
||||
And user "user2" exists
|
||||
And group "group0" exists
|
||||
And user "user1" belongs to group "group0"
|
||||
And user "user2" belongs to group "group0"
|
||||
And user "user0" created a folder "/common"
|
||||
And user "user0" created a folder "/common/sub"
|
||||
And file "common" of user "user0" is shared with group "group0"
|
||||
And file "textfile0.txt" of user "user1" is shared with user "user2"
|
||||
And User "user1" moved file "/textfile0.txt" to "/common/textfile0.txt"
|
||||
And User "user1" moved file "/common/textfile0.txt" to "/common/sub/textfile0.txt"
|
||||
And As an "user2"
|
||||
When Downloading file "/common/sub/textfile0.txt" with range "bytes=10-18"
|
||||
Then Downloaded content should be "test text"
|
||||
And Downloaded content when downloading file "/textfile0.txt" with range "bytes=10-18" should be "test text"
|
||||
And user "user2" should see following elements
|
||||
| /common/sub/textfile0.txt |
|
||||
|
||||
Scenario: Share a file by multiple channels
|
||||
Given As an "admin"
|
||||
And user "user0" exists
|
||||
And user "user1" exists
|
||||
And user "user2" exists
|
||||
And group "group0" exists
|
||||
And user "user1" belongs to group "group0"
|
||||
And user "user2" belongs to group "group0"
|
||||
And user "user0" created a folder "/common"
|
||||
And user "user0" created a folder "/common/sub"
|
||||
And file "common" of user "user0" is shared with group "group0"
|
||||
And file "textfile0.txt" of user "user1" is shared with user "user2"
|
||||
And User "user1" moved file "/textfile0.txt" to "/common/textfile0.txt"
|
||||
And User "user1" moved file "/common/textfile0.txt" to "/common/sub/textfile0.txt"
|
||||
And As an "user2"
|
||||
When Downloading file "/textfile0.txt" with range "bytes=10-18"
|
||||
Then Downloaded content should be "test text"
|
||||
And user "user2" should see following elements
|
||||
| /common/sub/textfile0.txt |
|
||||
|
||||
Scenario: Delete all group shares
|
||||
Given As an "admin"
|
||||
And user "user0" exists
|
||||
And user "user1" exists
|
||||
And group "group1" exists
|
||||
And user "user1" belongs to group "group1"
|
||||
And file "textfile0.txt" of user "user0" is shared with group "group1"
|
||||
And User "user1" moved file "/textfile0.txt" to "/FOLDER/textfile0.txt"
|
||||
And As an "user0"
|
||||
And Deleting last share
|
||||
And As an "user1"
|
||||
When sending "GET" to "/apps/files_sharing/api/v1/shares?shared_with_me=true"
|
||||
Then the OCS status code should be "100"
|
||||
And the HTTP status code should be "200"
|
||||
And last share_id is not included in the answer
|
||||
|
||||
Scenario: delete a share
|
||||
Given user "user0" exists
|
||||
And user "user1" exists
|
||||
And file "textfile0.txt" of user "user0" is shared with user "user1"
|
||||
And As an "user0"
|
||||
When Deleting last share
|
||||
Then the OCS status code should be "100"
|
||||
And the HTTP status code should be "200"
|
||||
|
||||
Scenario: Keep usergroup shares (#22143)
|
||||
Given As an "admin"
|
||||
And user "user0" exists
|
||||
And user "user1" exists
|
||||
And user "user2" exists
|
||||
And group "group" exists
|
||||
And user "user1" belongs to group "group"
|
||||
And user "user2" belongs to group "group"
|
||||
And user "user0" created a folder "/TMP"
|
||||
And file "TMP" of user "user0" is shared with group "group"
|
||||
And user "user1" created a folder "/myFOLDER"
|
||||
And User "user1" moves file "/TMP" to "/myFOLDER/myTMP"
|
||||
And user "user2" does not exist
|
||||
And user "user1" should see following elements
|
||||
| /myFOLDER/myTMP/ |
|
||||
|
||||
Scenario: Check quota of owners parent directory of a shared file
|
||||
Given using old dav path
|
||||
And As an "admin"
|
||||
And user "user0" exists
|
||||
And user "user1" exists
|
||||
And user "user1" has a quota of "0"
|
||||
And User "user0" moved file "/welcome.txt" to "/myfile.txt"
|
||||
And file "myfile.txt" of user "user0" is shared with user "user1"
|
||||
When User "user1" uploads file "data/textfile.txt" to "/myfile.txt"
|
||||
Then the HTTP status code should be "204"
|
||||
|
||||
Scenario: Don't allow sharing of the root
|
||||
Given user "user0" exists
|
||||
And As an "user0"
|
||||
When creating a share with
|
||||
| path | / |
|
||||
| shareType | 3 |
|
||||
Then the OCS status code should be "403"
|
||||
|
||||
Scenario: Allow modification of reshare
|
||||
Given user "user0" exists
|
||||
And user "user1" exists
|
||||
And user "user2" exists
|
||||
And user "user0" created a folder "/TMP"
|
||||
And file "TMP" of user "user0" is shared with user "user1"
|
||||
And file "TMP" of user "user1" is shared with user "user2"
|
||||
And As an "user1"
|
||||
When Updating last share with
|
||||
| permissions | 1 |
|
||||
Then the OCS status code should be "100"
|
||||
|
||||
Scenario: Do not allow reshare to exceed permissions
|
||||
Given user "user0" exists
|
||||
And user "user1" exists
|
||||
And user "user2" exists
|
||||
And user "user0" created a folder "/TMP"
|
||||
And As an "user0"
|
||||
And creating a share with
|
||||
| path | /TMP |
|
||||
| shareType | 0 |
|
||||
| shareWith | user1 |
|
||||
| permissions | 21 |
|
||||
And As an "user1"
|
||||
And creating a share with
|
||||
| path | /TMP |
|
||||
| shareType | 0 |
|
||||
| shareWith | user2 |
|
||||
| permissions | 21 |
|
||||
When Updating last share with
|
||||
| permissions | 31 |
|
||||
Then the OCS status code should be "404"
|
||||
|
||||
Scenario: Only allow 1 link share per file/folder
|
||||
Given user "user0" exists
|
||||
And As an "user0"
|
||||
And creating a share with
|
||||
| path | welcome.txt |
|
||||
| shareType | 3 |
|
||||
When save last share id
|
||||
And creating a share with
|
||||
| path | welcome.txt |
|
||||
| shareType | 3 |
|
||||
Then share ids should match
|
||||
|
||||
Scenario: Correct webdav share-permissions for owned file
|
||||
Given user "user0" exists
|
||||
And User "user0" uploads file with content "foo" to "/tmp.txt"
|
||||
When as "user0" gets properties of folder "/tmp.txt" with
|
||||
|{http://open-collaboration-services.org/ns}share-permissions |
|
||||
Then the single response should contain a property "{http://open-collaboration-services.org/ns}share-permissions" with value "19"
|
||||
|
||||
Scenario: Correct webdav share-permissions for received file with edit and reshare permissions
|
||||
Given user "user0" exists
|
||||
And user "user1" exists
|
||||
And User "user0" uploads file with content "foo" to "/tmp.txt"
|
||||
And file "/tmp.txt" of user "user0" is shared with user "user1"
|
||||
When as "user1" gets properties of folder "/tmp.txt" with
|
||||
|{http://open-collaboration-services.org/ns}share-permissions |
|
||||
Then the single response should contain a property "{http://open-collaboration-services.org/ns}share-permissions" with value "19"
|
||||
|
||||
Scenario: Correct webdav share-permissions for received file with edit permissions but no reshare permissions
|
||||
Given user "user0" exists
|
||||
And user "user1" exists
|
||||
And User "user0" uploads file with content "foo" to "/tmp.txt"
|
||||
And file "tmp.txt" of user "user0" is shared with user "user1"
|
||||
And As an "user0"
|
||||
And Updating last share with
|
||||
| permissions | 3 |
|
||||
When as "user1" gets properties of folder "/tmp.txt" with
|
||||
|{http://open-collaboration-services.org/ns}share-permissions |
|
||||
Then the single response should contain a property "{http://open-collaboration-services.org/ns}share-permissions" with value "3"
|
||||
|
||||
Scenario: Correct webdav share-permissions for received file with reshare permissions but no edit permissions
|
||||
Given user "user0" exists
|
||||
And user "user1" exists
|
||||
And User "user0" uploads file with content "foo" to "/tmp.txt"
|
||||
And file "tmp.txt" of user "user0" is shared with user "user1"
|
||||
And As an "user0"
|
||||
And Updating last share with
|
||||
| permissions | 17 |
|
||||
When as "user1" gets properties of folder "/tmp.txt" with
|
||||
|{http://open-collaboration-services.org/ns}share-permissions |
|
||||
Then the single response should contain a property "{http://open-collaboration-services.org/ns}share-permissions" with value "17"
|
||||
|
||||
Scenario: Correct webdav share-permissions for owned folder
|
||||
Given user "user0" exists
|
||||
And user "user0" created a folder "/tmp"
|
||||
When as "user0" gets properties of folder "/" with
|
||||
|{http://open-collaboration-services.org/ns}share-permissions |
|
||||
Then the single response should contain a property "{http://open-collaboration-services.org/ns}share-permissions" with value "31"
|
||||
|
||||
Scenario: Correct webdav share-permissions for received folder with all permissions
|
||||
Given user "user0" exists
|
||||
And user "user1" exists
|
||||
And user "user0" created a folder "/tmp"
|
||||
And file "/tmp" of user "user0" is shared with user "user1"
|
||||
When as "user1" gets properties of folder "/tmp" with
|
||||
|{http://open-collaboration-services.org/ns}share-permissions |
|
||||
Then the single response should contain a property "{http://open-collaboration-services.org/ns}share-permissions" with value "31"
|
||||
|
||||
Scenario: Correct webdav share-permissions for received folder with all permissions but edit
|
||||
Given user "user0" exists
|
||||
And user "user1" exists
|
||||
And user "user0" created a folder "/tmp"
|
||||
And file "/tmp" of user "user0" is shared with user "user1"
|
||||
And As an "user0"
|
||||
And Updating last share with
|
||||
| permissions | 29 |
|
||||
When as "user1" gets properties of folder "/tmp" with
|
||||
|{http://open-collaboration-services.org/ns}share-permissions |
|
||||
Then the single response should contain a property "{http://open-collaboration-services.org/ns}share-permissions" with value "29"
|
||||
|
||||
Scenario: Correct webdav share-permissions for received folder with all permissions but create
|
||||
Given user "user0" exists
|
||||
And user "user1" exists
|
||||
And user "user0" created a folder "/tmp"
|
||||
And file "/tmp" of user "user0" is shared with user "user1"
|
||||
And As an "user0"
|
||||
And Updating last share with
|
||||
| permissions | 27 |
|
||||
When as "user1" gets properties of folder "/tmp" with
|
||||
|{http://open-collaboration-services.org/ns}share-permissions |
|
||||
Then the single response should contain a property "{http://open-collaboration-services.org/ns}share-permissions" with value "27"
|
||||
|
||||
Scenario: Correct webdav share-permissions for received folder with all permissions but delete
|
||||
Given user "user0" exists
|
||||
And user "user1" exists
|
||||
And user "user0" created a folder "/tmp"
|
||||
And file "/tmp" of user "user0" is shared with user "user1"
|
||||
And As an "user0"
|
||||
And Updating last share with
|
||||
| permissions | 23 |
|
||||
When as "user1" gets properties of folder "/tmp" with
|
||||
|{http://open-collaboration-services.org/ns}share-permissions |
|
||||
Then the single response should contain a property "{http://open-collaboration-services.org/ns}share-permissions" with value "23"
|
||||
|
||||
Scenario: Correct webdav share-permissions for received folder with all permissions but share
|
||||
Given user "user0" exists
|
||||
And user "user1" exists
|
||||
And user "user0" created a folder "/tmp"
|
||||
And file "/tmp" of user "user0" is shared with user "user1"
|
||||
And As an "user0"
|
||||
And Updating last share with
|
||||
| permissions | 15 |
|
||||
When as "user1" gets properties of folder "/tmp" with
|
||||
|{http://open-collaboration-services.org/ns}share-permissions |
|
||||
Then the single response should contain a property "{http://open-collaboration-services.org/ns}share-permissions" with value "15"
|
||||
|
||||
Scenario: unique target names for incoming shares
|
||||
Given user "user0" exists
|
||||
And user "user1" exists
|
||||
And user "user2" exists
|
||||
And user "user0" created a folder "/foo"
|
||||
And user "user1" created a folder "/foo"
|
||||
When file "/foo" of user "user0" is shared with user "user2"
|
||||
And file "/foo" of user "user1" is shared with user "user2"
|
||||
Then user "user2" should see following elements
|
||||
| /foo/ |
|
||||
| /foo%20(2)/ |
|
||||
|
||||
Scenario: Creating a new share with a disabled user
|
||||
Given As an "admin"
|
||||
And user "user0" exists
|
||||
And user "user1" exists
|
||||
And assure user "user0" is disabled
|
||||
And As an "user0"
|
||||
When sending "POST" to "/apps/files_sharing/api/v1/shares" with
|
||||
| path | welcome.txt |
|
||||
| shareWith | user1 |
|
||||
| shareType | 0 |
|
||||
Then the OCS status code should be "997"
|
||||
And the HTTP status code should be "401"
|
||||
|
||||
Scenario: Deleting a group share as user
|
||||
Given As an "admin"
|
||||
And user "user0" exists
|
||||
And user "user1" exists
|
||||
And group "group1" exists
|
||||
And user "user1" belongs to group "group1"
|
||||
And As an "user0"
|
||||
And creating a share with
|
||||
| path | welcome.txt |
|
||||
| shareType | 1 |
|
||||
| shareWith | group1 |
|
||||
When As an "user1"
|
||||
And Deleting last share
|
||||
Then the OCS status code should be "100"
|
||||
And the HTTP status code should be "200"
|
||||
|
||||
Scenario: Merging shares for recipient when shared from outside with group and member
|
||||
Given using old dav path
|
||||
And As an "admin"
|
||||
And user "user0" exists
|
||||
And user "user1" exists
|
||||
And group "group1" exists
|
||||
And user "user1" belongs to group "group1"
|
||||
And user "user0" created a folder "/merge-test-outside"
|
||||
When folder "/merge-test-outside" of user "user0" is shared with group "group1"
|
||||
And folder "/merge-test-outside" of user "user0" is shared with user "user1"
|
||||
Then as "user1" the folder "/merge-test-outside" exists
|
||||
And as "user1" the folder "/merge-test-outside (2)" does not exist
|
||||
|
||||
Scenario: Merging shares for recipient when shared from outside with group and member with different permissions
|
||||
Given As an "admin"
|
||||
And user "user0" exists
|
||||
And user "user1" exists
|
||||
And group "group1" exists
|
||||
And user "user1" belongs to group "group1"
|
||||
And user "user0" created a folder "/merge-test-outside-perms"
|
||||
When folder "/merge-test-outside-perms" of user "user0" is shared with group "group1" with permissions 1
|
||||
And folder "/merge-test-outside-perms" of user "user0" is shared with user "user1" with permissions 31
|
||||
Then as "user1" gets properties of folder "/merge-test-outside-perms" with
|
||||
|{http://owncloud.org/ns}permissions|
|
||||
And the single response should contain a property "{http://owncloud.org/ns}permissions" with value "SRDNVCK"
|
||||
And as "user1" the folder "/merge-test-outside-perms (2)" does not exist
|
||||
|
||||
Scenario: Merging shares for recipient when shared from outside with two groups
|
||||
Given As an "admin"
|
||||
And user "user0" exists
|
||||
And user "user1" exists
|
||||
And group "group1" exists
|
||||
And group "group2" exists
|
||||
And user "user1" belongs to group "group1"
|
||||
And user "user1" belongs to group "group2"
|
||||
And user "user0" created a folder "/merge-test-outside-twogroups"
|
||||
When folder "/merge-test-outside-twogroups" of user "user0" is shared with group "group1"
|
||||
And folder "/merge-test-outside-twogroups" of user "user0" is shared with group "group2"
|
||||
Then as "user1" the folder "/merge-test-outside-twogroups" exists
|
||||
And as "user1" the folder "/merge-test-outside-twogroups (2)" does not exist
|
||||
|
||||
Scenario: Merging shares for recipient when shared from outside with two groups with different permissions
|
||||
Given As an "admin"
|
||||
And user "user0" exists
|
||||
And user "user1" exists
|
||||
And group "group1" exists
|
||||
And group "group2" exists
|
||||
And user "user1" belongs to group "group1"
|
||||
And user "user1" belongs to group "group2"
|
||||
And user "user0" created a folder "/merge-test-outside-twogroups-perms"
|
||||
When folder "/merge-test-outside-twogroups-perms" of user "user0" is shared with group "group1" with permissions 1
|
||||
And folder "/merge-test-outside-twogroups-perms" of user "user0" is shared with group "group2" with permissions 31
|
||||
Then as "user1" gets properties of folder "/merge-test-outside-twogroups-perms" with
|
||||
|{http://owncloud.org/ns}permissions|
|
||||
And the single response should contain a property "{http://owncloud.org/ns}permissions" with value "SRDNVCK"
|
||||
And as "user1" the folder "/merge-test-outside-twogroups-perms (2)" does not exist
|
||||
|
||||
Scenario: Merging shares for recipient when shared from outside with two groups and member
|
||||
Given As an "admin"
|
||||
And user "user0" exists
|
||||
And user "user1" exists
|
||||
And group "group1" exists
|
||||
And group "group2" exists
|
||||
And user "user1" belongs to group "group1"
|
||||
And user "user1" belongs to group "group2"
|
||||
And user "user0" created a folder "/merge-test-outside-twogroups-member-perms"
|
||||
When folder "/merge-test-outside-twogroups-member-perms" of user "user0" is shared with group "group1" with permissions 1
|
||||
And folder "/merge-test-outside-twogroups-member-perms" of user "user0" is shared with group "group2" with permissions 31
|
||||
And folder "/merge-test-outside-twogroups-member-perms" of user "user0" is shared with user "user1" with permissions 1
|
||||
Then as "user1" gets properties of folder "/merge-test-outside-twogroups-member-perms" with
|
||||
|{http://owncloud.org/ns}permissions|
|
||||
And the single response should contain a property "{http://owncloud.org/ns}permissions" with value "SRDNVCK"
|
||||
And as "user1" the folder "/merge-test-outside-twogroups-member-perms (2)" does not exist
|
||||
|
||||
Scenario: Merging shares for recipient when shared from inside with group
|
||||
Given As an "admin"
|
||||
And user "user0" exists
|
||||
And group "group1" exists
|
||||
And user "user0" belongs to group "group1"
|
||||
And user "user0" created a folder "/merge-test-inside-group"
|
||||
When folder "/merge-test-inside-group" of user "user0" is shared with group "group1"
|
||||
Then as "user0" the folder "/merge-test-inside-group" exists
|
||||
And as "user0" the folder "/merge-test-inside-group (2)" does not exist
|
||||
|
||||
Scenario: Merging shares for recipient when shared from inside with two groups
|
||||
Given As an "admin"
|
||||
And user "user0" exists
|
||||
And group "group1" exists
|
||||
And group "group2" exists
|
||||
And user "user0" belongs to group "group1"
|
||||
And user "user0" belongs to group "group2"
|
||||
And user "user0" created a folder "/merge-test-inside-twogroups"
|
||||
When folder "/merge-test-inside-twogroups" of user "user0" is shared with group "group1"
|
||||
And folder "/merge-test-inside-twogroups" of user "user0" is shared with group "group2"
|
||||
Then as "user0" the folder "/merge-test-inside-twogroups" exists
|
||||
And as "user0" the folder "/merge-test-inside-twogroups (2)" does not exist
|
||||
And as "user0" the folder "/merge-test-inside-twogroups (3)" does not exist
|
||||
|
||||
Scenario: Merging shares for recipient when shared from inside with group with less permissions
|
||||
Given As an "admin"
|
||||
And user "user0" exists
|
||||
And group "group1" exists
|
||||
And group "group2" exists
|
||||
And user "user0" belongs to group "group1"
|
||||
And user "user0" belongs to group "group2"
|
||||
And user "user0" created a folder "/merge-test-inside-twogroups-perms"
|
||||
When folder "/merge-test-inside-twogroups-perms" of user "user0" is shared with group "group1"
|
||||
And folder "/merge-test-inside-twogroups-perms" of user "user0" is shared with group "group2"
|
||||
Then as "user0" gets properties of folder "/merge-test-inside-twogroups-perms" with
|
||||
|{http://owncloud.org/ns}permissions|
|
||||
And the single response should contain a property "{http://owncloud.org/ns}permissions" with value "RDNVCK"
|
||||
And as "user0" the folder "/merge-test-inside-twogroups-perms (2)" does not exist
|
||||
And as "user0" the folder "/merge-test-inside-twogroups-perms (3)" does not exist
|
||||
|
||||
Scenario: Merging shares for recipient when shared from outside with group then user and recipient renames in between
|
||||
Given As an "admin"
|
||||
And user "user0" exists
|
||||
And user "user1" exists
|
||||
And group "group1" exists
|
||||
And user "user1" belongs to group "group1"
|
||||
And user "user0" created a folder "/merge-test-outside-groups-renamebeforesecondshare"
|
||||
When folder "/merge-test-outside-groups-renamebeforesecondshare" of user "user0" is shared with group "group1"
|
||||
And User "user1" moved folder "/merge-test-outside-groups-renamebeforesecondshare" to "/merge-test-outside-groups-renamebeforesecondshare-renamed"
|
||||
And Sleep for "1" seconds
|
||||
And folder "/merge-test-outside-groups-renamebeforesecondshare" of user "user0" is shared with user "user1"
|
||||
Then as "user1" gets properties of folder "/merge-test-outside-groups-renamebeforesecondshare-renamed" with
|
||||
|{http://owncloud.org/ns}permissions|
|
||||
And the single response should contain a property "{http://owncloud.org/ns}permissions" with value "SRDNVCK"
|
||||
And as "user1" the folder "/merge-test-outside-groups-renamebeforesecondshare" does not exist
|
||||
|
||||
Scenario: Merging shares for recipient when shared from outside with user then group and recipient renames in between
|
||||
Given using old dav path
|
||||
Given As an "admin"
|
||||
And user "user0" exists
|
||||
And user "user1" exists
|
||||
And group "group1" exists
|
||||
And user "user1" belongs to group "group1"
|
||||
And user "user0" created a folder "/merge-test-outside-groups-renamebeforesecondshare"
|
||||
When folder "/merge-test-outside-groups-renamebeforesecondshare" of user "user0" is shared with user "user1"
|
||||
And User "user1" moved folder "/merge-test-outside-groups-renamebeforesecondshare" to "/merge-test-outside-groups-renamebeforesecondshare-renamed"
|
||||
And Sleep for "1" seconds
|
||||
And folder "/merge-test-outside-groups-renamebeforesecondshare" of user "user0" is shared with group "group1"
|
||||
Then as "user1" gets properties of folder "/merge-test-outside-groups-renamebeforesecondshare-renamed" with
|
||||
|{http://owncloud.org/ns}permissions|
|
||||
And the single response should contain a property "{http://owncloud.org/ns}permissions" with value "SRDNVCK"
|
||||
And as "user1" the folder "/merge-test-outside-groups-renamebeforesecondshare" does not exist
|
||||
|
||||
Scenario: Empting trashbin
|
||||
Given As an "admin"
|
||||
And user "user0" exists
|
||||
And User "user0" deletes file "/textfile0.txt"
|
||||
When User "user0" empties trashbin
|
||||
Then the HTTP status code should be "200"
|
||||
|
||||
Scenario: orphaned shares
|
||||
Given As an "admin"
|
||||
And user "user0" exists
|
||||
And user "user1" exists
|
||||
And user "user0" created a folder "/common"
|
||||
And user "user0" created a folder "/common/sub"
|
||||
And file "/common/sub" of user "user0" is shared with user "user1"
|
||||
And User "user0" deletes folder "/common"
|
||||
When User "user0" empties trashbin
|
||||
Then as "user1" the folder "/sub" does not exist
|
||||
|
||||
Scenario: sharing again an own file while belonging to a group
|
||||
Given As an "admin"
|
||||
Given user "user0" exists
|
||||
And group "sharing-group" exists
|
||||
And user "user0" belongs to group "sharing-group"
|
||||
And file "welcome.txt" of user "user0" is shared with group "sharing-group"
|
||||
And Deleting last share
|
||||
When sending "POST" to "/apps/files_sharing/api/v1/shares" with
|
||||
| path | welcome.txt |
|
||||
| shareWith | sharing-group |
|
||||
| shareType | 1 |
|
||||
Then the OCS status code should be "100"
|
||||
And the HTTP status code should be "200"
|
||||
|
||||
Scenario: unshare from self
|
||||
Given As an "admin"
|
||||
And user "user0" exists
|
||||
And user "user1" exists
|
||||
And group "sharing-group" exists
|
||||
And user "user0" belongs to group "sharing-group"
|
||||
And user "user1" belongs to group "sharing-group"
|
||||
And file "/PARENT/parent.txt" of user "user0" is shared with group "sharing-group"
|
||||
And user "user0" stores etag of element "/PARENT"
|
||||
And user "user1" stores etag of element "/"
|
||||
And As an "user1"
|
||||
When Deleting last share
|
||||
Then etag of element "/" of user "user1" has changed
|
||||
And etag of element "/PARENT" of user "user0" has not changed
|
||||
|
||||
Scenario: do not allow to increase link share permissions on reshare
|
||||
Given As an "admin"
|
||||
And user "admin" created a folder "/TMP"
|
||||
And user "user0" exists
|
||||
And creating a share with
|
||||
| path | TMP |
|
||||
| shareType | 0 |
|
||||
| shareWith | user0 |
|
||||
| permissions | 17 |
|
||||
When As an "user0"
|
||||
And creating a share with
|
||||
| path | TMP |
|
||||
| shareType | 3 |
|
||||
And Updating last share with
|
||||
| publicUpload | true |
|
||||
Then the OCS status code should be "404"
|
||||
|
||||
Scenario: moving a file into a share as recipient
|
||||
Given As an "admin"
|
||||
And user "user0" exists
|
||||
And user "user1" exists
|
||||
And user "user0" created a folder "/shared"
|
||||
And folder "/shared" of user "user0" is shared with user "user1"
|
||||
When User "user1" moved file "/textfile0.txt" to "/shared/shared_file.txt"
|
||||
Then as "user1" the file "/shared/shared_file.txt" exists
|
||||
And as "user0" the file "/shared/shared_file.txt" exists
|
|
@ -288,713 +288,4 @@ Feature: sharing
|
|||
And User "user2" should be included in the response
|
||||
And User "user3" should not be included in the response
|
||||
|
||||
Scenario: getting all shares of a file with reshares
|
||||
Given user "user0" exists
|
||||
And user "user1" exists
|
||||
And user "user2" exists
|
||||
And user "user3" exists
|
||||
And file "textfile0.txt" of user "user0" is shared with user "user1"
|
||||
And file "textfile0 (2).txt" of user "user1" is shared with user "user2"
|
||||
And As an "user0"
|
||||
When sending "GET" to "/apps/files_sharing/api/v1/shares?reshares=true&path=textfile0.txt"
|
||||
Then the OCS status code should be "100"
|
||||
And the HTTP status code should be "200"
|
||||
And User "user1" should be included in the response
|
||||
And User "user2" should be included in the response
|
||||
And User "user3" should not be included in the response
|
||||
|
||||
Scenario: Reshared files can be still accessed if a user in the middle removes it.
|
||||
Given user "user0" exists
|
||||
And user "user1" exists
|
||||
And user "user2" exists
|
||||
And user "user3" exists
|
||||
And file "textfile0.txt" of user "user0" is shared with user "user1"
|
||||
And file "textfile0 (2).txt" of user "user1" is shared with user "user2"
|
||||
And file "textfile0 (2).txt" of user "user2" is shared with user "user3"
|
||||
And As an "user1"
|
||||
When User "user1" deletes file "/textfile0 (2).txt"
|
||||
And As an "user3"
|
||||
And Downloading file "/textfile0 (2).txt" with range "bytes=1-8"
|
||||
Then Downloaded content should be "extcloud"
|
||||
|
||||
Scenario: getting share info of a share
|
||||
Given user "user0" exists
|
||||
And user "user1" exists
|
||||
And file "textfile0.txt" of user "user0" is shared with user "user1"
|
||||
And As an "user0"
|
||||
When Getting info of last share
|
||||
Then the OCS status code should be "100"
|
||||
And the HTTP status code should be "200"
|
||||
And Share fields of last share match with
|
||||
| id | A_NUMBER |
|
||||
| item_type | file |
|
||||
| item_source | A_NUMBER |
|
||||
| share_type | 0 |
|
||||
| share_with | user1 |
|
||||
| file_source | A_NUMBER |
|
||||
| file_target | /textfile0.txt |
|
||||
| path | /textfile0.txt |
|
||||
| permissions | 19 |
|
||||
| stime | A_NUMBER |
|
||||
| storage | A_NUMBER |
|
||||
| mail_send | 0 |
|
||||
| uid_owner | user0 |
|
||||
| storage_id | home::user0 |
|
||||
| file_parent | A_NUMBER |
|
||||
| share_with_displayname | user1 |
|
||||
| displayname_owner | user0 |
|
||||
| mimetype | text/plain |
|
||||
|
||||
Scenario: keep group permissions in sync
|
||||
Given As an "admin"
|
||||
Given user "user0" exists
|
||||
And user "user1" exists
|
||||
And group "group1" exists
|
||||
And user "user1" belongs to group "group1"
|
||||
And file "textfile0.txt" of user "user0" is shared with group "group1"
|
||||
And User "user1" moved file "/textfile0.txt" to "/FOLDER/textfile0.txt"
|
||||
And As an "user0"
|
||||
When Updating last share with
|
||||
| permissions | 1 |
|
||||
And Getting info of last share
|
||||
Then the OCS status code should be "100"
|
||||
And the HTTP status code should be "200"
|
||||
And Share fields of last share match with
|
||||
| id | A_NUMBER |
|
||||
| item_type | file |
|
||||
| item_source | A_NUMBER |
|
||||
| share_type | 1 |
|
||||
| file_source | A_NUMBER |
|
||||
| file_target | /textfile0.txt |
|
||||
| permissions | 1 |
|
||||
| stime | A_NUMBER |
|
||||
| storage | A_NUMBER |
|
||||
| mail_send | 0 |
|
||||
| uid_owner | user0 |
|
||||
| storage_id | home::user0 |
|
||||
| file_parent | A_NUMBER |
|
||||
| displayname_owner | user0 |
|
||||
| mimetype | text/plain |
|
||||
|
||||
Scenario: Sharee can see the share
|
||||
Given user "user0" exists
|
||||
And user "user1" exists
|
||||
And file "textfile0.txt" of user "user0" is shared with user "user1"
|
||||
And As an "user1"
|
||||
When sending "GET" to "/apps/files_sharing/api/v1/shares?shared_with_me=true"
|
||||
Then the OCS status code should be "100"
|
||||
And the HTTP status code should be "200"
|
||||
And last share_id is included in the answer
|
||||
|
||||
Scenario: Sharee can see the filtered share
|
||||
Given user "user0" exists
|
||||
And user "user1" exists
|
||||
And file "textfile0.txt" of user "user0" is shared with user "user1"
|
||||
And file "textfile1.txt" of user "user0" is shared with user "user1"
|
||||
And As an "user1"
|
||||
When sending "GET" to "/apps/files_sharing/api/v1/shares?shared_with_me=true&path=textfile1 (2).txt"
|
||||
Then the OCS status code should be "100"
|
||||
And the HTTP status code should be "200"
|
||||
And last share_id is included in the answer
|
||||
|
||||
Scenario: Sharee can't see the share that is filtered out
|
||||
Given user "user0" exists
|
||||
And user "user1" exists
|
||||
And file "textfile0.txt" of user "user0" is shared with user "user1"
|
||||
And file "textfile1.txt" of user "user0" is shared with user "user1"
|
||||
And As an "user1"
|
||||
When sending "GET" to "/apps/files_sharing/api/v1/shares?shared_with_me=true&path=textfile0 (2).txt"
|
||||
Then the OCS status code should be "100"
|
||||
And the HTTP status code should be "200"
|
||||
And last share_id is not included in the answer
|
||||
|
||||
Scenario: Sharee can see the group share
|
||||
Given As an "admin"
|
||||
And user "user0" exists
|
||||
And user "user1" exists
|
||||
And group "group0" exists
|
||||
And user "user1" belongs to group "group0"
|
||||
And file "textfile0.txt" of user "user0" is shared with group "group0"
|
||||
And As an "user1"
|
||||
When sending "GET" to "/apps/files_sharing/api/v1/shares?shared_with_me=true"
|
||||
Then the OCS status code should be "100"
|
||||
And the HTTP status code should be "200"
|
||||
And last share_id is included in the answer
|
||||
|
||||
Scenario: User is not allowed to reshare file
|
||||
As an "admin"
|
||||
Given user "user0" exists
|
||||
And user "user1" exists
|
||||
And user "user2" exists
|
||||
And As an "user0"
|
||||
And creating a share with
|
||||
| path | /textfile0.txt |
|
||||
| shareType | 0 |
|
||||
| shareWith | user1 |
|
||||
| permissions | 8 |
|
||||
And As an "user1"
|
||||
When creating a share with
|
||||
| path | /textfile0 (2).txt |
|
||||
| shareType | 0 |
|
||||
| shareWith | user2 |
|
||||
| permissions | 31 |
|
||||
Then the OCS status code should be "404"
|
||||
And the HTTP status code should be "200"
|
||||
|
||||
Scenario: User is not allowed to reshare file with more permissions
|
||||
As an "admin"
|
||||
Given user "user0" exists
|
||||
And user "user1" exists
|
||||
And user "user2" exists
|
||||
And As an "user0"
|
||||
And creating a share with
|
||||
| path | /textfile0.txt |
|
||||
| shareType | 0 |
|
||||
| shareWith | user1 |
|
||||
| permissions | 16 |
|
||||
And As an "user1"
|
||||
When creating a share with
|
||||
| path | /textfile0 (2).txt |
|
||||
| shareType | 0 |
|
||||
| shareWith | user2 |
|
||||
| permissions | 31 |
|
||||
Then the OCS status code should be "404"
|
||||
And the HTTP status code should be "200"
|
||||
|
||||
Scenario: Get a share with a user which didn't received the share
|
||||
Given user "user0" exists
|
||||
And user "user1" exists
|
||||
And user "user2" exists
|
||||
And file "textfile0.txt" of user "user0" is shared with user "user1"
|
||||
And As an "user2"
|
||||
When Getting info of last share
|
||||
Then the OCS status code should be "404"
|
||||
And the HTTP status code should be "200"
|
||||
|
||||
Scenario: Share of folder and sub-folder to same user - core#20645
|
||||
Given As an "admin"
|
||||
And user "user0" exists
|
||||
And user "user1" exists
|
||||
And group "group0" exists
|
||||
And user "user1" belongs to group "group0"
|
||||
And file "/PARENT" of user "user0" is shared with user "user1"
|
||||
When file "/PARENT/CHILD" of user "user0" is shared with group "group0"
|
||||
Then user "user1" should see following elements
|
||||
| /FOLDER/ |
|
||||
| /PARENT/ |
|
||||
| /CHILD/ |
|
||||
| /PARENT/parent.txt |
|
||||
| /CHILD/child.txt |
|
||||
And the HTTP status code should be "200"
|
||||
|
||||
Scenario: Share a file by multiple channels
|
||||
Given As an "admin"
|
||||
And user "user0" exists
|
||||
And user "user1" exists
|
||||
And user "user2" exists
|
||||
And group "group0" exists
|
||||
And user "user1" belongs to group "group0"
|
||||
And user "user2" belongs to group "group0"
|
||||
And user "user0" created a folder "/common"
|
||||
And user "user0" created a folder "/common/sub"
|
||||
And file "common" of user "user0" is shared with group "group0"
|
||||
And file "textfile0.txt" of user "user1" is shared with user "user2"
|
||||
And User "user1" moved file "/textfile0.txt" to "/common/textfile0.txt"
|
||||
And User "user1" moved file "/common/textfile0.txt" to "/common/sub/textfile0.txt"
|
||||
And As an "user2"
|
||||
When Downloading file "/common/sub/textfile0.txt" with range "bytes=10-18"
|
||||
Then Downloaded content should be "test text"
|
||||
And Downloaded content when downloading file "/textfile0.txt" with range "bytes=10-18" should be "test text"
|
||||
And user "user2" should see following elements
|
||||
| /common/sub/textfile0.txt |
|
||||
|
||||
Scenario: Share a file by multiple channels
|
||||
Given As an "admin"
|
||||
And user "user0" exists
|
||||
And user "user1" exists
|
||||
And user "user2" exists
|
||||
And group "group0" exists
|
||||
And user "user1" belongs to group "group0"
|
||||
And user "user2" belongs to group "group0"
|
||||
And user "user0" created a folder "/common"
|
||||
And user "user0" created a folder "/common/sub"
|
||||
And file "common" of user "user0" is shared with group "group0"
|
||||
And file "textfile0.txt" of user "user1" is shared with user "user2"
|
||||
And User "user1" moved file "/textfile0.txt" to "/common/textfile0.txt"
|
||||
And User "user1" moved file "/common/textfile0.txt" to "/common/sub/textfile0.txt"
|
||||
And As an "user2"
|
||||
When Downloading file "/textfile0.txt" with range "bytes=10-18"
|
||||
Then Downloaded content should be "test text"
|
||||
And user "user2" should see following elements
|
||||
| /common/sub/textfile0.txt |
|
||||
|
||||
Scenario: Delete all group shares
|
||||
Given As an "admin"
|
||||
And user "user0" exists
|
||||
And user "user1" exists
|
||||
And group "group1" exists
|
||||
And user "user1" belongs to group "group1"
|
||||
And file "textfile0.txt" of user "user0" is shared with group "group1"
|
||||
And User "user1" moved file "/textfile0.txt" to "/FOLDER/textfile0.txt"
|
||||
And As an "user0"
|
||||
And Deleting last share
|
||||
And As an "user1"
|
||||
When sending "GET" to "/apps/files_sharing/api/v1/shares?shared_with_me=true"
|
||||
Then the OCS status code should be "100"
|
||||
And the HTTP status code should be "200"
|
||||
And last share_id is not included in the answer
|
||||
|
||||
Scenario: delete a share
|
||||
Given user "user0" exists
|
||||
And user "user1" exists
|
||||
And file "textfile0.txt" of user "user0" is shared with user "user1"
|
||||
And As an "user0"
|
||||
When Deleting last share
|
||||
Then the OCS status code should be "100"
|
||||
And the HTTP status code should be "200"
|
||||
|
||||
Scenario: Keep usergroup shares (#22143)
|
||||
Given As an "admin"
|
||||
And user "user0" exists
|
||||
And user "user1" exists
|
||||
And user "user2" exists
|
||||
And group "group" exists
|
||||
And user "user1" belongs to group "group"
|
||||
And user "user2" belongs to group "group"
|
||||
And user "user0" created a folder "/TMP"
|
||||
And file "TMP" of user "user0" is shared with group "group"
|
||||
And user "user1" created a folder "/myFOLDER"
|
||||
And User "user1" moves file "/TMP" to "/myFOLDER/myTMP"
|
||||
And user "user2" does not exist
|
||||
And user "user1" should see following elements
|
||||
| /myFOLDER/myTMP/ |
|
||||
|
||||
Scenario: Check quota of owners parent directory of a shared file
|
||||
Given using old dav path
|
||||
And As an "admin"
|
||||
And user "user0" exists
|
||||
And user "user1" exists
|
||||
And user "user1" has a quota of "0"
|
||||
And User "user0" moved file "/welcome.txt" to "/myfile.txt"
|
||||
And file "myfile.txt" of user "user0" is shared with user "user1"
|
||||
When User "user1" uploads file "data/textfile.txt" to "/myfile.txt"
|
||||
Then the HTTP status code should be "204"
|
||||
|
||||
Scenario: Don't allow sharing of the root
|
||||
Given user "user0" exists
|
||||
And As an "user0"
|
||||
When creating a share with
|
||||
| path | / |
|
||||
| shareType | 3 |
|
||||
Then the OCS status code should be "403"
|
||||
|
||||
Scenario: Allow modification of reshare
|
||||
Given user "user0" exists
|
||||
And user "user1" exists
|
||||
And user "user2" exists
|
||||
And user "user0" created a folder "/TMP"
|
||||
And file "TMP" of user "user0" is shared with user "user1"
|
||||
And file "TMP" of user "user1" is shared with user "user2"
|
||||
And As an "user1"
|
||||
When Updating last share with
|
||||
| permissions | 1 |
|
||||
Then the OCS status code should be "100"
|
||||
|
||||
Scenario: Do not allow reshare to exceed permissions
|
||||
Given user "user0" exists
|
||||
And user "user1" exists
|
||||
And user "user2" exists
|
||||
And user "user0" created a folder "/TMP"
|
||||
And As an "user0"
|
||||
And creating a share with
|
||||
| path | /TMP |
|
||||
| shareType | 0 |
|
||||
| shareWith | user1 |
|
||||
| permissions | 21 |
|
||||
And As an "user1"
|
||||
And creating a share with
|
||||
| path | /TMP |
|
||||
| shareType | 0 |
|
||||
| shareWith | user2 |
|
||||
| permissions | 21 |
|
||||
When Updating last share with
|
||||
| permissions | 31 |
|
||||
Then the OCS status code should be "404"
|
||||
|
||||
Scenario: Only allow 1 link share per file/folder
|
||||
Given user "user0" exists
|
||||
And As an "user0"
|
||||
And creating a share with
|
||||
| path | welcome.txt |
|
||||
| shareType | 3 |
|
||||
When save last share id
|
||||
And creating a share with
|
||||
| path | welcome.txt |
|
||||
| shareType | 3 |
|
||||
Then share ids should match
|
||||
|
||||
Scenario: Correct webdav share-permissions for owned file
|
||||
Given user "user0" exists
|
||||
And User "user0" uploads file with content "foo" to "/tmp.txt"
|
||||
When as "user0" gets properties of folder "/tmp.txt" with
|
||||
|{http://open-collaboration-services.org/ns}share-permissions |
|
||||
Then the single response should contain a property "{http://open-collaboration-services.org/ns}share-permissions" with value "19"
|
||||
|
||||
Scenario: Correct webdav share-permissions for received file with edit and reshare permissions
|
||||
Given user "user0" exists
|
||||
And user "user1" exists
|
||||
And User "user0" uploads file with content "foo" to "/tmp.txt"
|
||||
And file "/tmp.txt" of user "user0" is shared with user "user1"
|
||||
When as "user1" gets properties of folder "/tmp.txt" with
|
||||
|{http://open-collaboration-services.org/ns}share-permissions |
|
||||
Then the single response should contain a property "{http://open-collaboration-services.org/ns}share-permissions" with value "19"
|
||||
|
||||
Scenario: Correct webdav share-permissions for received file with edit permissions but no reshare permissions
|
||||
Given user "user0" exists
|
||||
And user "user1" exists
|
||||
And User "user0" uploads file with content "foo" to "/tmp.txt"
|
||||
And file "tmp.txt" of user "user0" is shared with user "user1"
|
||||
And As an "user0"
|
||||
And Updating last share with
|
||||
| permissions | 3 |
|
||||
When as "user1" gets properties of folder "/tmp.txt" with
|
||||
|{http://open-collaboration-services.org/ns}share-permissions |
|
||||
Then the single response should contain a property "{http://open-collaboration-services.org/ns}share-permissions" with value "3"
|
||||
|
||||
Scenario: Correct webdav share-permissions for received file with reshare permissions but no edit permissions
|
||||
Given user "user0" exists
|
||||
And user "user1" exists
|
||||
And User "user0" uploads file with content "foo" to "/tmp.txt"
|
||||
And file "tmp.txt" of user "user0" is shared with user "user1"
|
||||
And As an "user0"
|
||||
And Updating last share with
|
||||
| permissions | 17 |
|
||||
When as "user1" gets properties of folder "/tmp.txt" with
|
||||
|{http://open-collaboration-services.org/ns}share-permissions |
|
||||
Then the single response should contain a property "{http://open-collaboration-services.org/ns}share-permissions" with value "17"
|
||||
|
||||
Scenario: Correct webdav share-permissions for owned folder
|
||||
Given user "user0" exists
|
||||
And user "user0" created a folder "/tmp"
|
||||
When as "user0" gets properties of folder "/" with
|
||||
|{http://open-collaboration-services.org/ns}share-permissions |
|
||||
Then the single response should contain a property "{http://open-collaboration-services.org/ns}share-permissions" with value "31"
|
||||
|
||||
Scenario: Correct webdav share-permissions for received folder with all permissions
|
||||
Given user "user0" exists
|
||||
And user "user1" exists
|
||||
And user "user0" created a folder "/tmp"
|
||||
And file "/tmp" of user "user0" is shared with user "user1"
|
||||
When as "user1" gets properties of folder "/tmp" with
|
||||
|{http://open-collaboration-services.org/ns}share-permissions |
|
||||
Then the single response should contain a property "{http://open-collaboration-services.org/ns}share-permissions" with value "31"
|
||||
|
||||
Scenario: Correct webdav share-permissions for received folder with all permissions but edit
|
||||
Given user "user0" exists
|
||||
And user "user1" exists
|
||||
And user "user0" created a folder "/tmp"
|
||||
And file "/tmp" of user "user0" is shared with user "user1"
|
||||
And As an "user0"
|
||||
And Updating last share with
|
||||
| permissions | 29 |
|
||||
When as "user1" gets properties of folder "/tmp" with
|
||||
|{http://open-collaboration-services.org/ns}share-permissions |
|
||||
Then the single response should contain a property "{http://open-collaboration-services.org/ns}share-permissions" with value "29"
|
||||
|
||||
Scenario: Correct webdav share-permissions for received folder with all permissions but create
|
||||
Given user "user0" exists
|
||||
And user "user1" exists
|
||||
And user "user0" created a folder "/tmp"
|
||||
And file "/tmp" of user "user0" is shared with user "user1"
|
||||
And As an "user0"
|
||||
And Updating last share with
|
||||
| permissions | 27 |
|
||||
When as "user1" gets properties of folder "/tmp" with
|
||||
|{http://open-collaboration-services.org/ns}share-permissions |
|
||||
Then the single response should contain a property "{http://open-collaboration-services.org/ns}share-permissions" with value "27"
|
||||
|
||||
Scenario: Correct webdav share-permissions for received folder with all permissions but delete
|
||||
Given user "user0" exists
|
||||
And user "user1" exists
|
||||
And user "user0" created a folder "/tmp"
|
||||
And file "/tmp" of user "user0" is shared with user "user1"
|
||||
And As an "user0"
|
||||
And Updating last share with
|
||||
| permissions | 23 |
|
||||
When as "user1" gets properties of folder "/tmp" with
|
||||
|{http://open-collaboration-services.org/ns}share-permissions |
|
||||
Then the single response should contain a property "{http://open-collaboration-services.org/ns}share-permissions" with value "23"
|
||||
|
||||
Scenario: Correct webdav share-permissions for received folder with all permissions but share
|
||||
Given user "user0" exists
|
||||
And user "user1" exists
|
||||
And user "user0" created a folder "/tmp"
|
||||
And file "/tmp" of user "user0" is shared with user "user1"
|
||||
And As an "user0"
|
||||
And Updating last share with
|
||||
| permissions | 15 |
|
||||
When as "user1" gets properties of folder "/tmp" with
|
||||
|{http://open-collaboration-services.org/ns}share-permissions |
|
||||
Then the single response should contain a property "{http://open-collaboration-services.org/ns}share-permissions" with value "15"
|
||||
|
||||
Scenario: unique target names for incoming shares
|
||||
Given user "user0" exists
|
||||
And user "user1" exists
|
||||
And user "user2" exists
|
||||
And user "user0" created a folder "/foo"
|
||||
And user "user1" created a folder "/foo"
|
||||
When file "/foo" of user "user0" is shared with user "user2"
|
||||
And file "/foo" of user "user1" is shared with user "user2"
|
||||
Then user "user2" should see following elements
|
||||
| /foo/ |
|
||||
| /foo%20(2)/ |
|
||||
|
||||
Scenario: Creating a new share with a disabled user
|
||||
Given As an "admin"
|
||||
And user "user0" exists
|
||||
And user "user1" exists
|
||||
And assure user "user0" is disabled
|
||||
And As an "user0"
|
||||
When sending "POST" to "/apps/files_sharing/api/v1/shares" with
|
||||
| path | welcome.txt |
|
||||
| shareWith | user1 |
|
||||
| shareType | 0 |
|
||||
Then the OCS status code should be "997"
|
||||
And the HTTP status code should be "401"
|
||||
|
||||
Scenario: Deleting a group share as user
|
||||
Given As an "admin"
|
||||
And user "user0" exists
|
||||
And user "user1" exists
|
||||
And group "group1" exists
|
||||
And user "user1" belongs to group "group1"
|
||||
And As an "user0"
|
||||
And creating a share with
|
||||
| path | welcome.txt |
|
||||
| shareType | 1 |
|
||||
| shareWith | group1 |
|
||||
When As an "user1"
|
||||
And Deleting last share
|
||||
Then the OCS status code should be "100"
|
||||
And the HTTP status code should be "200"
|
||||
|
||||
Scenario: Merging shares for recipient when shared from outside with group and member
|
||||
Given using old dav path
|
||||
And As an "admin"
|
||||
And user "user0" exists
|
||||
And user "user1" exists
|
||||
And group "group1" exists
|
||||
And user "user1" belongs to group "group1"
|
||||
And user "user0" created a folder "/merge-test-outside"
|
||||
When folder "/merge-test-outside" of user "user0" is shared with group "group1"
|
||||
And folder "/merge-test-outside" of user "user0" is shared with user "user1"
|
||||
Then as "user1" the folder "/merge-test-outside" exists
|
||||
And as "user1" the folder "/merge-test-outside (2)" does not exist
|
||||
|
||||
Scenario: Merging shares for recipient when shared from outside with group and member with different permissions
|
||||
Given As an "admin"
|
||||
And user "user0" exists
|
||||
And user "user1" exists
|
||||
And group "group1" exists
|
||||
And user "user1" belongs to group "group1"
|
||||
And user "user0" created a folder "/merge-test-outside-perms"
|
||||
When folder "/merge-test-outside-perms" of user "user0" is shared with group "group1" with permissions 1
|
||||
And folder "/merge-test-outside-perms" of user "user0" is shared with user "user1" with permissions 31
|
||||
Then as "user1" gets properties of folder "/merge-test-outside-perms" with
|
||||
|{http://owncloud.org/ns}permissions|
|
||||
And the single response should contain a property "{http://owncloud.org/ns}permissions" with value "SRDNVCK"
|
||||
And as "user1" the folder "/merge-test-outside-perms (2)" does not exist
|
||||
|
||||
Scenario: Merging shares for recipient when shared from outside with two groups
|
||||
Given As an "admin"
|
||||
And user "user0" exists
|
||||
And user "user1" exists
|
||||
And group "group1" exists
|
||||
And group "group2" exists
|
||||
And user "user1" belongs to group "group1"
|
||||
And user "user1" belongs to group "group2"
|
||||
And user "user0" created a folder "/merge-test-outside-twogroups"
|
||||
When folder "/merge-test-outside-twogroups" of user "user0" is shared with group "group1"
|
||||
And folder "/merge-test-outside-twogroups" of user "user0" is shared with group "group2"
|
||||
Then as "user1" the folder "/merge-test-outside-twogroups" exists
|
||||
And as "user1" the folder "/merge-test-outside-twogroups (2)" does not exist
|
||||
|
||||
Scenario: Merging shares for recipient when shared from outside with two groups with different permissions
|
||||
Given As an "admin"
|
||||
And user "user0" exists
|
||||
And user "user1" exists
|
||||
And group "group1" exists
|
||||
And group "group2" exists
|
||||
And user "user1" belongs to group "group1"
|
||||
And user "user1" belongs to group "group2"
|
||||
And user "user0" created a folder "/merge-test-outside-twogroups-perms"
|
||||
When folder "/merge-test-outside-twogroups-perms" of user "user0" is shared with group "group1" with permissions 1
|
||||
And folder "/merge-test-outside-twogroups-perms" of user "user0" is shared with group "group2" with permissions 31
|
||||
Then as "user1" gets properties of folder "/merge-test-outside-twogroups-perms" with
|
||||
|{http://owncloud.org/ns}permissions|
|
||||
And the single response should contain a property "{http://owncloud.org/ns}permissions" with value "SRDNVCK"
|
||||
And as "user1" the folder "/merge-test-outside-twogroups-perms (2)" does not exist
|
||||
|
||||
Scenario: Merging shares for recipient when shared from outside with two groups and member
|
||||
Given As an "admin"
|
||||
And user "user0" exists
|
||||
And user "user1" exists
|
||||
And group "group1" exists
|
||||
And group "group2" exists
|
||||
And user "user1" belongs to group "group1"
|
||||
And user "user1" belongs to group "group2"
|
||||
And user "user0" created a folder "/merge-test-outside-twogroups-member-perms"
|
||||
When folder "/merge-test-outside-twogroups-member-perms" of user "user0" is shared with group "group1" with permissions 1
|
||||
And folder "/merge-test-outside-twogroups-member-perms" of user "user0" is shared with group "group2" with permissions 31
|
||||
And folder "/merge-test-outside-twogroups-member-perms" of user "user0" is shared with user "user1" with permissions 1
|
||||
Then as "user1" gets properties of folder "/merge-test-outside-twogroups-member-perms" with
|
||||
|{http://owncloud.org/ns}permissions|
|
||||
And the single response should contain a property "{http://owncloud.org/ns}permissions" with value "SRDNVCK"
|
||||
And as "user1" the folder "/merge-test-outside-twogroups-member-perms (2)" does not exist
|
||||
|
||||
Scenario: Merging shares for recipient when shared from inside with group
|
||||
Given As an "admin"
|
||||
And user "user0" exists
|
||||
And group "group1" exists
|
||||
And user "user0" belongs to group "group1"
|
||||
And user "user0" created a folder "/merge-test-inside-group"
|
||||
When folder "/merge-test-inside-group" of user "user0" is shared with group "group1"
|
||||
Then as "user0" the folder "/merge-test-inside-group" exists
|
||||
And as "user0" the folder "/merge-test-inside-group (2)" does not exist
|
||||
|
||||
Scenario: Merging shares for recipient when shared from inside with two groups
|
||||
Given As an "admin"
|
||||
And user "user0" exists
|
||||
And group "group1" exists
|
||||
And group "group2" exists
|
||||
And user "user0" belongs to group "group1"
|
||||
And user "user0" belongs to group "group2"
|
||||
And user "user0" created a folder "/merge-test-inside-twogroups"
|
||||
When folder "/merge-test-inside-twogroups" of user "user0" is shared with group "group1"
|
||||
And folder "/merge-test-inside-twogroups" of user "user0" is shared with group "group2"
|
||||
Then as "user0" the folder "/merge-test-inside-twogroups" exists
|
||||
And as "user0" the folder "/merge-test-inside-twogroups (2)" does not exist
|
||||
And as "user0" the folder "/merge-test-inside-twogroups (3)" does not exist
|
||||
|
||||
Scenario: Merging shares for recipient when shared from inside with group with less permissions
|
||||
Given As an "admin"
|
||||
And user "user0" exists
|
||||
And group "group1" exists
|
||||
And group "group2" exists
|
||||
And user "user0" belongs to group "group1"
|
||||
And user "user0" belongs to group "group2"
|
||||
And user "user0" created a folder "/merge-test-inside-twogroups-perms"
|
||||
When folder "/merge-test-inside-twogroups-perms" of user "user0" is shared with group "group1"
|
||||
And folder "/merge-test-inside-twogroups-perms" of user "user0" is shared with group "group2"
|
||||
Then as "user0" gets properties of folder "/merge-test-inside-twogroups-perms" with
|
||||
|{http://owncloud.org/ns}permissions|
|
||||
And the single response should contain a property "{http://owncloud.org/ns}permissions" with value "RDNVCK"
|
||||
And as "user0" the folder "/merge-test-inside-twogroups-perms (2)" does not exist
|
||||
And as "user0" the folder "/merge-test-inside-twogroups-perms (3)" does not exist
|
||||
|
||||
Scenario: Merging shares for recipient when shared from outside with group then user and recipient renames in between
|
||||
Given As an "admin"
|
||||
And user "user0" exists
|
||||
And user "user1" exists
|
||||
And group "group1" exists
|
||||
And user "user1" belongs to group "group1"
|
||||
And user "user0" created a folder "/merge-test-outside-groups-renamebeforesecondshare"
|
||||
When folder "/merge-test-outside-groups-renamebeforesecondshare" of user "user0" is shared with group "group1"
|
||||
And User "user1" moved folder "/merge-test-outside-groups-renamebeforesecondshare" to "/merge-test-outside-groups-renamebeforesecondshare-renamed"
|
||||
And Sleep for "1" seconds
|
||||
And folder "/merge-test-outside-groups-renamebeforesecondshare" of user "user0" is shared with user "user1"
|
||||
Then as "user1" gets properties of folder "/merge-test-outside-groups-renamebeforesecondshare-renamed" with
|
||||
|{http://owncloud.org/ns}permissions|
|
||||
And the single response should contain a property "{http://owncloud.org/ns}permissions" with value "SRDNVCK"
|
||||
And as "user1" the folder "/merge-test-outside-groups-renamebeforesecondshare" does not exist
|
||||
|
||||
Scenario: Merging shares for recipient when shared from outside with user then group and recipient renames in between
|
||||
Given using old dav path
|
||||
Given As an "admin"
|
||||
And user "user0" exists
|
||||
And user "user1" exists
|
||||
And group "group1" exists
|
||||
And user "user1" belongs to group "group1"
|
||||
And user "user0" created a folder "/merge-test-outside-groups-renamebeforesecondshare"
|
||||
When folder "/merge-test-outside-groups-renamebeforesecondshare" of user "user0" is shared with user "user1"
|
||||
And User "user1" moved folder "/merge-test-outside-groups-renamebeforesecondshare" to "/merge-test-outside-groups-renamebeforesecondshare-renamed"
|
||||
And Sleep for "1" seconds
|
||||
And folder "/merge-test-outside-groups-renamebeforesecondshare" of user "user0" is shared with group "group1"
|
||||
Then as "user1" gets properties of folder "/merge-test-outside-groups-renamebeforesecondshare-renamed" with
|
||||
|{http://owncloud.org/ns}permissions|
|
||||
And the single response should contain a property "{http://owncloud.org/ns}permissions" with value "SRDNVCK"
|
||||
And as "user1" the folder "/merge-test-outside-groups-renamebeforesecondshare" does not exist
|
||||
|
||||
Scenario: Empting trashbin
|
||||
Given As an "admin"
|
||||
And user "user0" exists
|
||||
And User "user0" deletes file "/textfile0.txt"
|
||||
When User "user0" empties trashbin
|
||||
Then the HTTP status code should be "200"
|
||||
|
||||
Scenario: orphaned shares
|
||||
Given As an "admin"
|
||||
And user "user0" exists
|
||||
And user "user1" exists
|
||||
And user "user0" created a folder "/common"
|
||||
And user "user0" created a folder "/common/sub"
|
||||
And file "/common/sub" of user "user0" is shared with user "user1"
|
||||
And User "user0" deletes folder "/common"
|
||||
When User "user0" empties trashbin
|
||||
Then as "user1" the folder "/sub" does not exist
|
||||
|
||||
Scenario: sharing again an own file while belonging to a group
|
||||
Given As an "admin"
|
||||
Given user "user0" exists
|
||||
And group "sharing-group" exists
|
||||
And user "user0" belongs to group "sharing-group"
|
||||
And file "welcome.txt" of user "user0" is shared with group "sharing-group"
|
||||
And Deleting last share
|
||||
When sending "POST" to "/apps/files_sharing/api/v1/shares" with
|
||||
| path | welcome.txt |
|
||||
| shareWith | sharing-group |
|
||||
| shareType | 1 |
|
||||
Then the OCS status code should be "100"
|
||||
And the HTTP status code should be "200"
|
||||
|
||||
Scenario: unshare from self
|
||||
Given As an "admin"
|
||||
And user "user0" exists
|
||||
And user "user1" exists
|
||||
And group "sharing-group" exists
|
||||
And user "user0" belongs to group "sharing-group"
|
||||
And user "user1" belongs to group "sharing-group"
|
||||
And file "/PARENT/parent.txt" of user "user0" is shared with group "sharing-group"
|
||||
And user "user0" stores etag of element "/PARENT"
|
||||
And user "user1" stores etag of element "/"
|
||||
And As an "user1"
|
||||
When Deleting last share
|
||||
Then etag of element "/" of user "user1" has changed
|
||||
And etag of element "/PARENT" of user "user0" has not changed
|
||||
|
||||
Scenario: do not allow to increase link share permissions on reshare
|
||||
Given As an "admin"
|
||||
And user "admin" created a folder "/TMP"
|
||||
And user "user0" exists
|
||||
And creating a share with
|
||||
| path | TMP |
|
||||
| shareType | 0 |
|
||||
| shareWith | user0 |
|
||||
| permissions | 17 |
|
||||
When As an "user0"
|
||||
And creating a share with
|
||||
| path | TMP |
|
||||
| shareType | 3 |
|
||||
And Updating last share with
|
||||
| publicUpload | true |
|
||||
Then the OCS status code should be "404"
|
||||
|
||||
Scenario: moving a file into a share as recipient
|
||||
Given As an "admin"
|
||||
And user "user0" exists
|
||||
And user "user1" exists
|
||||
And user "user0" created a folder "/shared"
|
||||
And folder "/shared" of user "user0" is shared with user "user1"
|
||||
When User "user1" moved file "/textfile0.txt" to "/shared/shared_file.txt"
|
||||
Then as "user1" the file "/shared/shared_file.txt" exists
|
||||
And as "user0" the file "/shared/shared_file.txt" exists
|
||||
# See sharing-v1-part2.feature
|
||||
|
|
Loading…
Reference in New Issue