From 60bfd5f6cf463a75fa38e6102a7c10c3ce9643b4 Mon Sep 17 00:00:00 2001 From: KarunAtreya Date: Thu, 3 Aug 2023 09:51:28 +0545 Subject: [PATCH] added test scenario for searching inside particular folder only --- .../features/apiGraph/fullSearch.feature | 21 ++++++++++++++++++ .../features/bootstrap/SearchContext.php | 22 ++++++++++++++----- 2 files changed, 38 insertions(+), 5 deletions(-) diff --git a/tests/acceptance/features/apiGraph/fullSearch.feature b/tests/acceptance/features/apiGraph/fullSearch.feature index af09fc01046..c0aa17edfb1 100644 --- a/tests/acceptance/features/apiGraph/fullSearch.feature +++ b/tests/acceptance/features/apiGraph/fullSearch.feature @@ -147,3 +147,24 @@ Feature: full text search | old | | new | | spaces | + + + Scenario Outline: search files inside the folder + Given using DAV path + And user "Alice" has uploaded file with content "hello world inside root" to "file1.txt" + And user "Alice" has created folder "/Folder" + And user "Alice" has uploaded file with content "hello world inside folder" to "/Folder/file2.txt" + And user "Alice" has created folder "/Folder/SubFolder" + And user "Alice" has uploaded file with content "hello world inside sub-folder" to "/Folder/SubFolder/file3.txt" + When user "Alice" searches for "file" inside folder "/Folder" using the WebDAV API + Then the HTTP status code should be "207" + And the search result of user "Alice" should contain only these entries: + | file2.txt | + | file3.txt | + But the search result of user "Alice" should not contain these entries: + | file1.txt | + Examples: + | dav-path-version | + | old | + | new | + | spaces | diff --git a/tests/acceptance/features/bootstrap/SearchContext.php b/tests/acceptance/features/bootstrap/SearchContext.php index a7ba04a84ad..2557bafcc97 100644 --- a/tests/acceptance/features/bootstrap/SearchContext.php +++ b/tests/acceptance/features/bootstrap/SearchContext.php @@ -39,18 +39,21 @@ class SearchContext implements Context { * @When user :user searches for :pattern and limits the results to :limit items using the WebDAV API * @When user :user searches for :pattern using the WebDAV API requesting these properties: * @When user :user searches for :pattern and limits the results to :limit items using the WebDAV API requesting these properties: + * @When user :user searches for :pattern inside folder :scope using the WebDAV API * * @param string $user * @param string $pattern * @param string|null $limit + * @param string|null $scope * @param TableNode|null $properties * * @return void */ public function userSearchesUsingWebDavAPI( - string $user, - string $pattern, - ?string $limit = null, + string $user, + string $pattern, + ?string $limit = null, + ?string $scope = null, TableNode $properties = null ):void { // Because indexing of newly uploaded files or directories with ocis is decoupled and occurs asynchronously, a short wait is necessary before searching files or folders. @@ -62,8 +65,17 @@ public function userSearchesUsingWebDavAPI( $body = "\n" . " \n" . - " \n" . - " $pattern\n"; + " \n"; + if ($scope !== null) { + $scope = \trim($scope, "/"); + if ($this->featureContext->getDavPathVersion() === 3) { + $rootPath = $this->featureContext->getPersonalSpaceIdForUser($user); + } else { + $rootPath = $this->featureContext->getUserIdByUserName($user); + } + $pattern .= " scope:$rootPath/$scope"; + } + $body .= "$pattern\n"; if ($limit !== null) { $body .= " $limit\n"; }