]> source.dussan.org Git - nextcloud-server.git/commitdiff
Split long running features/sharing-v1.feature into two smaller parts 4121/head
authorMorris Jobke <hey@morrisjobke.de>
Tue, 28 Mar 2017 15:57:18 +0000 (09:57 -0600)
committerMorris Jobke <hey@morrisjobke.de>
Tue, 28 Mar 2017 22:46:56 +0000 (16:46 -0600)
Signed-off-by: Morris Jobke <hey@morrisjobke.de>
.drone.yml
build/integration/features/sharing-v1-part2.feature [new file with mode: 0644]
build/integration/features/sharing-v1.feature

index 7efea13dcaa4a79e168ee6f61faf44a130d9b51a..dd4ec40420971423d42b3b1720c88a7362ff5ddf 100644 (file)
@@ -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
diff --git a/build/integration/features/sharing-v1-part2.feature b/build/integration/features/sharing-v1-part2.feature
new file mode 100644 (file)
index 0000000..284e5f9
--- /dev/null
@@ -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
\ No newline at end of file
index 74579f635271c95f68725eacdc30e62c7cae3bda..9678720b262e327d7fa41dff1067205a632bdf96 100644 (file)
@@ -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