diff --git a/.drone.star b/.drone.star index 5a552268eed..c8ecad02ae4 100644 --- a/.drone.star +++ b/.drone.star @@ -142,6 +142,13 @@ config = { "OCIS_ADD_RUN_SERVICES": "antivirus", }, }, + "apiFullTextSearch": { + "suites": [ + "apiFullTextSearch", + ], + "skip": False, + "tikaNeeded": True, + }, }, "apiTests": { "numberOfParts": 10, @@ -734,6 +741,7 @@ def localApiTestPipeline(ctx): "accounts_hash_difficulty": 4, "emailNeeded": False, "antivirusNeeded": False, + "tikaNeeded": False, } if "localApiTests" in config: @@ -754,7 +762,8 @@ def localApiTestPipeline(ctx): }, "steps": skipIfUnchanged(ctx, "acceptance-tests") + restoreBuildArtifactCache(ctx, "ocis-binary-amd64", "ocis/bin") + - ocisServer(storage, params["accounts_hash_difficulty"], extra_server_environment = params["extraServerEnvironment"], with_wrapper = True) + + (tikaService() if params["tikaNeeded"] else []) + + ocisServer(storage, params["accounts_hash_difficulty"], extra_server_environment = params["extraServerEnvironment"], with_wrapper = True, tika_enabled = params["tikaNeeded"]) + (waitForClamavService() if params["antivirusNeeded"] else []) + (waitForEmailService() if params["emailNeeded"] else []) + localApiTests(suite, storage, params["extraEnvironment"]), diff --git a/tests/acceptance/config/behat.yml b/tests/acceptance/config/behat.yml index c122e94cdb6..829aa67988d 100644 --- a/tests/acceptance/config/behat.yml +++ b/tests/acceptance/config/behat.yml @@ -211,6 +211,26 @@ default: - OcisConfigContext: - PublicWebDavContext: + apiFullTextSearch: + paths: + - '%paths.base%/../features/apiFullTextSearch' + context: *common_ldap_suite_context + contexts: + - SettingsContext: + - GraphContext: + - SpacesContext: + - PublicWebDavContext: + - FeatureContext: *common_feature_context_params + - SearchContext: + - CapabilitiesContext: + - FilesVersionsContext: + - OCSContext: + - TrashbinContext: + - PublicWebDavContext: + - WebDavPropertiesContext: + - FavoritesContext: + - ChecksumContext: + extensions: rdx\behatvars\BehatVariablesExtension: ~ diff --git a/tests/acceptance/features/apiFullTextSearch/search.feature b/tests/acceptance/features/apiFullTextSearch/search.feature new file mode 100644 index 00000000000..970e9d86d34 --- /dev/null +++ b/tests/acceptance/features/apiFullTextSearch/search.feature @@ -0,0 +1,27 @@ +@api +Feature: full text search + As a user + I want to do full text search + So that I can find the files with the content I am looking for + + Background: + Given user "Alice" has been created with default attributes and without skeleton files + + + Scenario Outline: search files by content + Given using DAV path + And user "Alice" has uploaded file with content "hello world from nepal" to "keywordAtStart.txt" + And user "Alice" has uploaded file with content "saying hello to the world" to "keywordAtMiddle.txt" + And user "Alice" has uploaded file with content "nepal want to say hello" to "keywordAtLast.txt" + And user "Alice" has uploaded file with content "namaste from nepal" to "hello.txt" + When user "Alice" searches for "Content:hello" using the WebDAV API + Then the HTTP status code should be "207" + And the search result of user "Alice" should contain only these files: + | keywordAtStart.txt | + | keywordAtMiddle.txt | + | keywordAtLast.txt | + Examples: + | dav-path-version | + | old | + | new | + | spaces |