From 91dbb660814e76e594567aff18ec070ff7695d2e Mon Sep 17 00:00:00 2001 From: prashant-gurung899 Date: Thu, 21 Nov 2024 15:31:42 +0545 Subject: [PATCH] add test to check activities after updating share in space context Signed-off-by: prashant-gurung899 --- .../acceptance/bootstrap/SharingNgContext.php | 25 ++- .../expected-failures-without-remotephp.md | 4 +- .../apiActivities/shareActivities.feature | 187 ++++++++++++++++++ .../updateShareInvitations.feature | 8 +- 4 files changed, 214 insertions(+), 10 deletions(-) diff --git a/tests/acceptance/bootstrap/SharingNgContext.php b/tests/acceptance/bootstrap/SharingNgContext.php index 360d328a938..2b6eb2885b3 100644 --- a/tests/acceptance/bootstrap/SharingNgContext.php +++ b/tests/acceptance/bootstrap/SharingNgContext.php @@ -509,7 +509,25 @@ public function userSendsTheFollowingSpaceShareInvitationToFederatedUserUsingPer } /** - * @When user :user updates the last resource share with the following using the Graph API: + * @Given user :user has updated the last resource share with the following properties: + * + * @param string $user + * @param TableNode $table + * + * @return void + */ + public function userHasUpdatedTheLastResourceShareWithTheFollowingProperties(string $user, TableNode $table): void { + $permissionID = $this->featureContext->shareNgGetLastCreatedUserGroupShareID(); + $response = $this->updateResourceShare( + $user, + $table, + $permissionID + ); + $this->featureContext->theHTTPStatusCodeShouldBe(200, "Expected response status code should be 200", $response); + } + + /** + * @When user :user updates the last resource share with the following properties using the Graph API: * * @param string $user * @param TableNode $table @@ -517,8 +535,7 @@ public function userSendsTheFollowingSpaceShareInvitationToFederatedUserUsingPer * @return void */ public function userUpdatesTheLastShareWithFollowingUsingGraphApi($user, TableNode $table) { - $response = $this->featureContext->shareNgGetLastCreatedUserGroupShare(); - $permissionID = json_decode($response->getBody()->getContents())->value[0]->id; + $permissionID = $this->featureContext->shareNgGetLastCreatedUserGroupShareID(); $this->featureContext->setResponse( $this->updateResourceShare( $user, @@ -678,7 +695,7 @@ public function userHasCreatedTheFollowingLinkShare(string $user, TableNode $bo } /** - * @Given /^user "([^"]*)" has updated the last resource|space link share with$/ + * @Given user :user has updated the last resource/space link share with * * @param string $user * @param TableNode $body diff --git a/tests/acceptance/expected-failures-without-remotephp.md b/tests/acceptance/expected-failures-without-remotephp.md index 0242186ec52..0c491c1554c 100644 --- a/tests/acceptance/expected-failures-without-remotephp.md +++ b/tests/acceptance/expected-failures-without-remotephp.md @@ -210,8 +210,8 @@ - [apiLocks/unlockFiles.feature:321](https://github.com/owncloud/ocis/blob/master/tests/acceptance/features/apiLocks/unlockFiles.feature#L321) - [apiLocks/unlockFiles.feature:322](https://github.com/owncloud/ocis/blob/master/tests/acceptance/features/apiLocks/unlockFiles.feature#L322) - [apiLocks/unlockFiles.feature:323](https://github.com/owncloud/ocis/blob/master/tests/acceptance/features/apiLocks/unlockFiles.feature#L323) -- [apiActivities/shareActivities.feature:1775](https://github.com/owncloud/ocis/blob/master/tests/acceptance/features/apiActivities/shareActivities.feature#L1775) -- [apiActivities/shareActivities.feature:1914](https://github.com/owncloud/ocis/blob/master/tests/acceptance/features/apiActivities/shareActivities.feature#L1914) +- [apiActivities/shareActivities.feature:1962](https://github.com/owncloud/ocis/blob/master/tests/acceptance/features/apiActivities/shareActivities.feature#L1962) +- [apiActivities/shareActivities.feature:2101](https://github.com/owncloud/ocis/blob/master/tests/acceptance/features/apiActivities/shareActivities.feature#L2101) - [apiAntivirus/antivirus.feature:114](https://github.com/owncloud/ocis/blob/master/tests/acceptance/features/apiAntivirus/antivirus.feature#L114) - [apiAntivirus/antivirus.feature:115](https://github.com/owncloud/ocis/blob/master/tests/acceptance/features/apiAntivirus/antivirus.feature#L115) - [apiAntivirus/antivirus.feature:116](https://github.com/owncloud/ocis/blob/master/tests/acceptance/features/apiAntivirus/antivirus.feature#L116) diff --git a/tests/acceptance/features/apiActivities/shareActivities.feature b/tests/acceptance/features/apiActivities/shareActivities.feature index c3be57082ef..bd885e01007 100644 --- a/tests/acceptance/features/apiActivities/shareActivities.feature +++ b/tests/acceptance/features/apiActivities/shareActivities.feature @@ -1350,6 +1350,193 @@ Feature: check share activity } """ + @issue-10011 @issue-10228 + Scenario: check share update activities of a folder from a project space + Given using spaces DAV path + And the administrator has assigned the role "Space Admin" to user "Alice" using the Graph API + And user "Alice" has created a space "new-space" with the default quota using the Graph API + And user "Alice" has created a folder "folderToShare" in space "new-space" + And user "Alice" has sent the following resource share invitation: + | resource | folderToShare | + | space | new-space | + | sharee | Brian | + | shareType | user | + | permissionsRole | Viewer | + And user "Alice" has updated the last resource share with the following properties: + | permissionsRole | Editor | + | expirationDateTime | 2200-07-15T14:00:00.000Z | + | space | new-space | + | resource | folderToShare | + When user "Alice" lists the activities of folder "folderToShare" from space "new-space" using the Graph API + Then the HTTP status code should be "200" + And the JSON data of the response should match + """ + { + "type": "object", + "required": ["value"], + "properties": { + "value": { + "type": "array", + "minItems": 3, + "maxItems": 3, + "uniqueItems": true, + "items": { + "oneOf": [ + { + "type": "object", + "required": ["id","template","times"], + "properties": { + "id": { + "type": "string", + "pattern": "^%user_id_pattern%$" + }, + "template": { + "type": "object", + "required": ["message","variables"], + "properties": { + "message": { + "const": "{user} added {resource} to {folder}" + } + } + } + } + }, + { + "type": "object", + "required": ["id","template","times"], + "properties": { + "id": { + "type": "string", + "pattern": "^%user_id_pattern%$" + }, + "template": { + "type": "object", + "required": ["message","variables"], + "properties": { + "message": { + "const": "{user} shared {resource} with {sharee}" + }, + "variables": { + "type": "object", + "required": ["folder","resource","sharee","user"], + "properties": { + "resource": { + "type": "object", + "required": ["id","name"], + "properties": { + "name": { + "const": "folderToShare" + } + } + }, + "sharee": { + "type": "object", + "required": ["id","displayName"], + "properties": { + "displayName": { + "const": "Brian" + } + } + }, + "user": { + "type": "object", + "required": ["id","displayName"], + "properties": { + "displayName": { + "const": "Alice Hansen" + } + } + } + } + } + } + } + } + }, + { + "type": "object", + "required": ["id","template","times"], + "properties": { + "id": { + "type": "string", + "pattern": "^%user_id_pattern%$" + }, + "template": { + "type": "object", + "required": ["message","variables"], + "properties": { + "message": { + "const": "{user} updated {field} for the {resource}" + }, + "variables": { + "type": "object", + "required": ["field","folder","resource","user"], + "properties": { + "field": { + "type": "object", + "required": ["id","name"], + "properties": { + "name": { + "const": "expiration date, permission" + } + } + }, + "folder": { + "type": "object", + "required": ["id","name"], + "properties": { + "id": { + "type": "string", + "pattern": "%user_id_pattern%" + }, + "name": { + "const": "new-space" + } + } + }, + "resource": { + "type": "object", + "required": ["id","name"], + "properties": { + "id": { + "type": "string", + "pattern": "%file_id_pattern%" + }, + "name": { + "const": "folderToShare" + } + } + }, + "user": { + "type": "object", + "required": ["id","displayName"], + "properties": { + "id": { + "type": "string", + "pattern": "%user_id_pattern%" + }, + "displayName": { + "const": "Alice Hansen" + } + } + } + } + } + } + }, + "times": { + "type": "object", + "required": ["recordedTime"] + } + } + } + ] + } + } + } + } + """ + @issue-10012 Scenario: check link share activities of a file from a project space Given using spaces DAV path diff --git a/tests/acceptance/features/apiSharingNgShareInvitation/updateShareInvitations.feature b/tests/acceptance/features/apiSharingNgShareInvitation/updateShareInvitations.feature index e6d9ace64d8..a411bf5296e 100644 --- a/tests/acceptance/features/apiSharingNgShareInvitation/updateShareInvitations.feature +++ b/tests/acceptance/features/apiSharingNgShareInvitation/updateShareInvitations.feature @@ -20,7 +20,7 @@ Feature: Update permission of a share | shareType | user | | permissionsRole | Viewer | | expirationDateTime | 2025-07-15T14:00:00Z | - When user "Alice" updates the last resource share with the following using the Graph API: + When user "Alice" updates the last resource share with the following properties using the Graph API: | space | Personal | | resource | testfile.txt | | expirationDateTime | 2200-07-15T14:00:00Z | @@ -92,7 +92,7 @@ Feature: Update permission of a share | shareType | user | | permissionsRole | Viewer | | expirationDateTime | 2025-07-15T14:00:00Z | - When user "Alice" updates the last resource share with the following using the Graph API: + When user "Alice" updates the last resource share with the following properties using the Graph API: | space | Personal | | resource | | | expirationDateTime | | @@ -162,7 +162,7 @@ Feature: Update permission of a share | sharee | Brian | | shareType | user | | permissionsRole | | - When user "Alice" updates the last resource share with the following using the Graph API: + When user "Alice" updates the last resource share with the following properties using the Graph API: | permissionsRole | | | space | Personal | | resource | | @@ -314,7 +314,7 @@ Feature: Update permission of a share | sharee | Brian | | shareType | user | | permissionsRole | | - When user "Alice" updates the last resource share with the following using the Graph API: + When user "Alice" updates the last resource share with the following properties using the Graph API: | permissionsRole | | | space | NewSpace | | resource | |