diff --git a/tests/acceptance/features/apiGraph/fullSearch.feature b/tests/acceptance/features/apiGraph/fullSearch.feature index 28a991d76f2..26418659493 100644 --- a/tests/acceptance/features/apiGraph/fullSearch.feature +++ b/tests/acceptance/features/apiGraph/fullSearch.feature @@ -108,3 +108,24 @@ Feature: full text search | old | | new | | spaces | + + + Scenario Outline: search files inside the current 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 SubFolder" 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..1396e387e78 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,18 @@ 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); + } + $body .= "*$pattern* scope:$rootPath/$scope\n"; + } else { + $body .= "$pattern\n"; + } if ($limit !== null) { $body .= " $limit\n"; }