-
Notifications
You must be signed in to change notification settings - Fork 187
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
- Loading branch information
Showing
1 changed file
with
268 additions
and
0 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,268 @@ | ||
@api @skipOnOcV10 | ||
Feature: copy file | ||
As a user | ||
I want to be able to copy files | ||
So that I can manage my files | ||
|
||
Background: | ||
Given these users have been created with default attributes and without skeleton files: | ||
| username | | ||
| Alice | | ||
| Brian | | ||
|
||
|
||
Scenario Outline: Copying a file within a same space project with role manager and editor | ||
Given the administrator has given "Alice" the role "Space Admin" using the settings api | ||
And user "Alice" has created a space "Project" with the default quota using the GraphApi | ||
And user "Alice" has created a folder "newfolder" in space "Project" | ||
And user "Alice" has uploaded a file inside space "Project" with content "some content" to "insideSpace.txt" | ||
And user "Alice" has shared a space "Project" to user "Brian" with role "<role>" | ||
When user "Brian" copies file "insideSpace.txt" to "newfolder/insideSpace.txt" in space "Project" using the WebDAV API | ||
And the HTTP status code should be "201" | ||
And for user "Alice" the content of the file "newfolder/insideSpace.txt" of the space "Project" should be "some content" | ||
Examples: | ||
| role | | ||
| manager | | ||
| editor | | ||
|
||
|
||
Scenario: Copying a file within a same space project with role viewer | ||
Given the administrator has given "Alice" the role "Space Admin" using the settings api | ||
And user "Alice" has created a space "Project" with the default quota using the GraphApi | ||
And user "Alice" has created a folder "newfolder" in space "Project" | ||
And user "Alice" has uploaded a file inside space "Project" with content "some content" to "insideSpace.txt" | ||
And user "Alice" has shared a space "Project" to user "Brian" with role "viewer" | ||
When user "Brian" copies file "insideSpace.txt" to "newfolder/insideSpace.txt" in space "Project" using the WebDAV API | ||
And the HTTP status code should be "403" | ||
|
||
|
||
Scenario Outline: User copy a file from a space project with different role to a space project with manager role | ||
Given the administrator has given "Brian" the role "Space Admin" using the settings api | ||
And user "Brian" has created a space "Project1" with the default quota using the GraphApi | ||
And user "Brian" has created a space "Project2" with the default quota using the GraphApi | ||
And user "Brian" has uploaded a file inside space "Project1" with content "Project1 content" to "project1.txt" | ||
And user "Brian" has shared a space "Project2" to user "Alice" with role "manager" | ||
And user "Brian" has shared a space "Project1" to user "Alice" with role "<role>" | ||
When user "Alice" copies file "project1.txt" from space "Project1" to "project1.txt" inside space "Project2" using the WebDAV API | ||
And the HTTP status code should be "201" | ||
And for user "Alice" the content of the file "project1.txt" of the space "Project2" should be "Project1 content" | ||
Examples: | ||
| role | | ||
| manager | | ||
| editor | | ||
| viewer | | ||
|
||
|
||
Scenario Outline: User copy a file from a space project with different role to a space project with editor role | ||
Given the administrator has given "Brian" the role "Space Admin" using the settings api | ||
And user "Brian" has created a space "Project1" with the default quota using the GraphApi | ||
And user "Brian" has created a space "Project2" with the default quota using the GraphApi | ||
And user "Brian" has uploaded a file inside space "Project1" with content "Project1 content" to "project1.txt" | ||
And user "Brian" has shared a space "Project2" to user "Alice" with role "editor" | ||
And user "Brian" has shared a space "Project1" to user "Alice" with role "<role>" | ||
When user "Alice" copies file "project1.txt" from space "Project1" to "project1.txt" inside space "Project2" using the WebDAV API | ||
And the HTTP status code should be "201" | ||
And for user "Alice" the content of the file "project1.txt" of the space "Project2" should be "Project1 content" | ||
Examples: | ||
| role | | ||
| manager | | ||
| editor | | ||
| viewer | | ||
|
||
|
||
Scenario Outline: User copy a file from a space project with different role to a space project with viewer role | ||
Given the administrator has given "Brian" the role "Space Admin" using the settings api | ||
And user "Brian" has created a space "Project1" with the default quota using the GraphApi | ||
And user "Brian" has created a space "Project2" with the default quota using the GraphApi | ||
And user "Brian" has uploaded a file inside space "Project1" with content "Project1 content" to "project1.txt" | ||
And user "Brian" has shared a space "Project2" to user "Alice" with role "viewer" | ||
And user "Brian" has shared a space "Project1" to user "Alice" with role "<role>" | ||
When user "Alice" copies file "project1.txt" from space "Project1" to "project1.txt" inside space "Project2" using the WebDAV API | ||
And the HTTP status code should be "403" | ||
Examples: | ||
| role | | ||
| manager | | ||
| editor | | ||
|
||
|
||
Scenario Outline: User copy a file from space project with different role to space personal | ||
Given the administrator has given "Brian" the role "Space Admin" using the settings api | ||
And user "Brian" has created a space "Project" with the default quota using the GraphApi | ||
And user "Brian" has uploaded a file inside space "Project" with content "Project content" to "project.txt" | ||
And user "Brian" has shared a space "Project" to user "Alice" with role "<role>" | ||
When user "Alice" copies file "project.txt" from space "Project" to "project.txt" inside space "Personal" using the WebDAV API | ||
Then the HTTP status code should be "201" | ||
And as "Alice" file "/project.txt" should exist | ||
And the content of file "project.txt" for user "Alice" should be "Project content" | ||
Examples: | ||
| role | | ||
| manager | | ||
| editor | | ||
| viewer | | ||
|
||
|
||
Scenario Outline: User copy a file from space project with different role to space shares jail with editor role | ||
Given the administrator has given "Brian" the role "Space Admin" using the settings api | ||
And user "Brian" has created a space "Project" with the default quota using the GraphApi | ||
And user "Brian" has created folder "/testshare" | ||
And user "Brian" has uploaded a file inside space "Project" with content "Project content" to "project.txt" | ||
And user "Brian" has shared a space "Project" to user "Alice" with role "<role>" | ||
And user "Brian" has shared folder "/testshare" with user "Alice" with permissions "31" | ||
And user "Alice" has accepted share "/testshare" offered by user "Brian" | ||
When user "Alice" copies file "project.txt" from space "Project" to "/testshare/project.txt" inside space "Shares Jail" using the WebDAV API | ||
Then the HTTP status code should be "201" | ||
And as "Alice" file "/Shares/testshare/project.txt" should exist | ||
And the content of file "/Shares/testshare/project.txt" for user "Alice" should be "Project content" | ||
Examples: | ||
| role | | ||
| manager | | ||
| editor | | ||
| viewer | | ||
|
||
|
||
Scenario Outline: User copy a file from space project with different role to shares jail with viewer role | ||
Given the administrator has given "Brian" the role "Space Admin" using the settings api | ||
And user "Brian" has created a space "Project" with the default quota using the GraphApi | ||
And user "Brian" has created folder "/testshare" | ||
And user "Brian" has uploaded a file inside space "Project" with content "Project content" to "project.txt" | ||
And user "Brian" has shared a space "Project" to user "Alice" with role "<role>" | ||
And user "Brian" has shared folder "/testshare" with user "Alice" with permissions "17" | ||
And user "Alice" has accepted share "/testshare" offered by user "Brian" | ||
When user "Alice" copies file "project.txt" from space "Project" to "/testshare/project.txt" inside space "Shares Jail" using the WebDAV API | ||
Then the HTTP status code should be "403" | ||
Examples: | ||
| role | | ||
| manager | | ||
| editor | | ||
| viewer | | ||
|
||
|
||
Scenario Outline: User copy a file from space personal to space project with different role | ||
Given the administrator has given "Brian" the role "Space Admin" using the settings api | ||
And user "Brian" has created a space "Project" with the default quota using the GraphApi | ||
And user "Brian" has shared a space "Project" to user "Alice" with role "<role>" | ||
And user "Alice" has uploaded file with content "personal space content" to "/personal.txt" | ||
When user "Alice" copies file "personal.txt" from space "Personal" to "personal.txt" inside space "Project" using the WebDAV API | ||
Then the HTTP status code should be "201" | ||
And for user "Alice" the content of the file "personal.txt" of the space "Project" should be "personal space content" | ||
Examples: | ||
| role | | ||
| manager | | ||
| editor | | ||
|
||
|
||
Scenario: User copy a file from space personal to space project with role viewer | ||
Given the administrator has given "Brian" the role "Space Admin" using the settings api | ||
And user "Brian" has created a space "Project" with the default quota using the GraphApi | ||
And user "Brian" has shared a space "Project" to user "Alice" with role "viewer" | ||
And user "Alice" has uploaded file with content "personal space content" to "/personal.txt" | ||
When user "Alice" copies file "personal.txt" from space "Personal" to "personal.txt" inside space "Project" using the WebDAV API | ||
Then the HTTP status code should be "403" | ||
|
||
|
||
Scenario: User copy a file from space personal to space shares jail with role editor | ||
Given user "Brian" has created folder "/testshare" | ||
And user "Brian" has shared folder "/testshare" with user "Alice" with permissions "31" | ||
And user "Alice" has accepted share "/testshare" offered by user "Brian" | ||
And user "Alice" has uploaded file with content "personal content" to "personal.txt" | ||
When user "Alice" copies file "personal.txt" from space "Personal" to "/testshare/personal.txt" inside space "Shares Jail" using the WebDAV API | ||
Then the HTTP status code should be "201" | ||
And the content of file "/Shares/testshare/personal.txt" for user "Alice" should be "personal content" | ||
|
||
|
||
Scenario: User copy a file from space personal to space shares jail with role viewer | ||
Given user "Brian" has created folder "/testshare" | ||
And user "Brian" has shared folder "/testshare" with user "Alice" with permissions "17" | ||
And user "Alice" has accepted share "/testshare" offered by user "Brian" | ||
And user "Alice" has uploaded file with content "personal content" to "personal.txt" | ||
When user "Alice" copies file "personal.txt" from space "Personal" to "/testshare/personal.txt" inside space "Shares Jail" using the WebDAV API | ||
Then the HTTP status code should be "403" | ||
|
||
|
||
Scenario Outline: User copy a file from space shares jail with different role to space personal | ||
Given the administrator has given "Brian" the role "Space Admin" using the settings api | ||
And user "Brian" has created folder "/testshare" | ||
And user "Brian" has uploaded file with content "testshare content" to "/testshare/testshare.txt" | ||
And user "Brian" has shared folder "/testshare" with user "Alice" with permissions "<permissions>" | ||
And user "Alice" has accepted share "/testshare" offered by user "Brian" | ||
When user "Alice" copies file "/testshare/testshare.txt" from space "Shares Jail" to "testshare.txt" inside space "Personal" using the WebDAV API | ||
Then the HTTP status code should be "201" | ||
And as "Alice" file "/testshare.txt" should exist | ||
And the content of file "testshare.txt" for user "Alice" should be "testshare content" | ||
Examples: | ||
| permissions | | ||
| 31 | | ||
| 17 | | ||
|
||
|
||
Scenario Outline: User copy a file from space shares jail with different role to space project with different role | ||
Given the administrator has given "Brian" the role "Space Admin" using the settings api | ||
And user "Brian" has created a space "Project" with the default quota using the GraphApi | ||
And user "Brian" has shared a space "Project" to user "Alice" with role "<role>" | ||
And user "Brian" has created folder "/testshare" | ||
And user "Brian" has uploaded file with content "testshare content" to "/testshare/testshare.txt" | ||
And user "Brian" has shared folder "/testshare" with user "Alice" with permissions "<permissions>" | ||
And user "Alice" has accepted share "/testshare" offered by user "Brian" | ||
When user "Alice" copies file "/testshare/testshare.txt" from space "Shares Jail" to "testshare.txt" inside space "Project" using the WebDAV API | ||
Then the HTTP status code should be "201" | ||
And for user "Alice" the content of the file "testshare.txt" of the space "Project" should be "testshare content" | ||
Examples: | ||
| role | permissions | | ||
| manager | 31 | | ||
| manager | 17 | | ||
| editor | 31 | | ||
| editor | 17 | | ||
|
||
|
||
Scenario Outline: User copy a file from space shares jail with different role to space project with role viewer | ||
Given the administrator has given "Brian" the role "Space Admin" using the settings api | ||
And user "Brian" has created a space "Project" with the default quota using the GraphApi | ||
And user "Brian" has shared a space "Project" to user "Alice" with role "viewer" | ||
And user "Brian" has created folder "/testshare" | ||
And user "Brian" has uploaded file with content "testshare content" to "/testshare/testshare.txt" | ||
And user "Brian" has shared folder "/testshare" with user "Alice" with permissions "<permissions>" | ||
And user "Alice" has accepted share "/testshare" offered by user "Brian" | ||
When user "Alice" copies file "/testshare/testshare.txt" from space "Shares Jail" to "testshare.txt" inside space "Project" using the WebDAV API | ||
Then the HTTP status code should be "403" | ||
Examples: | ||
| permissions | | ||
| 31 | | ||
| 17 | | ||
|
||
|
||
Scenario Outline: User copy a file from space shares jail with different role to space shares jail with role editor | ||
Given user "Brian" has created folder "/testshare1" | ||
And user "Brian" has created folder "/testshare2" | ||
And user "Brian" has uploaded file with content "testshare1 content" to "/testshare1/testshare1.txt" | ||
And user "Brian" has shared folder "/testshare1" with user "Alice" with permissions "<permissions>" | ||
And user "Brian" has shared folder "/testshare2" with user "Alice" with permissions "31" | ||
And user "Alice" has accepted share "/testshare1" offered by user "Brian" | ||
And user "Alice" has accepted share "/testshare2" offered by user "Brian" | ||
When user "Alice" copies file "/testshare1/testshare1.txt" from space "Shares Jail" to "/testshare2/testshare1.txt" inside space "Shares Jail" using the WebDAV API | ||
Then the HTTP status code should be "201" | ||
And as "Alice" file "/Shares/testshare2/testshare1.txt" should exist | ||
And as "Brian" file "/testshare2/testshare1.txt" should exist | ||
And the content of file "/Shares/testshare2/testshare1.txt" for user "Alice" should be "testshare1 content" | ||
And the content of file "/testshare2/testshare1.txt" for user "Brian" should be "testshare1 content" | ||
Examples: | ||
| permissions | | ||
| 31 | | ||
| 17 | | ||
|
||
|
||
Scenario Outline: User copy a file from space shares jail with different role to space shares jail with role editor | ||
Given user "Brian" has created folder "/testshare1" | ||
And user "Brian" has created folder "/testshare2" | ||
And user "Brian" has uploaded file with content "testshare1 content" to "/testshare1/testshare1.txt" | ||
And user "Brian" has shared folder "/testshare1" with user "Alice" with permissions "<permissions>" | ||
And user "Brian" has shared folder "/testshare2" with user "Alice" with permissions "17" | ||
And user "Alice" has accepted share "/testshare1" offered by user "Brian" | ||
And user "Alice" has accepted share "/testshare2" offered by user "Brian" | ||
When user "Alice" copies file "/testshare1/testshare1.txt" from space "Shares Jail" to "/testshare2/testshare1.txt" inside space "Shares Jail" using the WebDAV API | ||
Then the HTTP status code should be "403" | ||
And as "Alice" file "/Shares/testshare2/testshare1.txt" should not exist | ||
And as "Brian" file "/testshare2/testshare1.txt" should not exist | ||
Examples: | ||
| permissions | | ||
| 31 | | ||
| 17 | |