elastic-enterprise-search 7.12.1 → 7.15.0

Sign up to get free protection for your applications and to get access to all the features.
Files changed (236) hide show
  1. checksums.yaml +4 -4
  2. data/.ci/functions/imports.sh +1 -0
  3. data/.ci/jobs/defaults.yml +4 -0
  4. data/.ci/jobs/elastic+enterprise-search-ruby+7.10.0.beta.1.yml +12 -0
  5. data/.ci/jobs/{elastic+enterprise-search-ruby+7.11.yml → elastic+enterprise-search-ruby+main.yml} +4 -4
  6. data/.ci/make.sh +162 -0
  7. data/.ci/run-repository.sh +2 -1
  8. data/.ci/test-matrix.yml +5 -3
  9. data/{spec/app-search/api_logs_spec.rb → .github/check_license_headers.rb} +13 -16
  10. data/.github/license-header.txt +16 -0
  11. data/.github/workflows/license.yml +13 -0
  12. data/.github/workflows/testing.yml +1 -1
  13. data/CONTRIBUTING.md +1 -1
  14. data/README.md +1 -1
  15. data/Rakefile +20 -0
  16. data/docs/guide/app-search-api.asciidoc +157 -1
  17. data/docs/guide/connecting.asciidoc +47 -1
  18. data/docs/guide/overview.asciidoc +3 -3
  19. data/docs/guide/release_notes/712.asciidoc +0 -10
  20. data/docs/guide/release_notes/713.asciidoc +21 -0
  21. data/docs/guide/release_notes/714.asciidoc +21 -0
  22. data/docs/guide/release_notes/715.asciidoc +36 -0
  23. data/docs/guide/release_notes/index.asciidoc +6 -0
  24. data/docs/guide/workplace-search-api.asciidoc +115 -2
  25. data/elastic-enterprise-search.gemspec +1 -1
  26. data/lib/elastic/app-search/api/add_meta_engine_source.rb +3 -2
  27. data/lib/elastic/app-search/api/api_key.rb +52 -0
  28. data/lib/elastic/app-search/api/api_logs.rb +14 -13
  29. data/lib/elastic/app-search/api/count_analytics.rb +7 -6
  30. data/lib/elastic/app-search/api/crawler_active_crawl_request.rb +51 -0
  31. data/lib/elastic/app-search/api/crawler_crawl_request.rb +54 -0
  32. data/lib/elastic/app-search/api/crawler_crawl_schedule.rb +51 -0
  33. data/lib/elastic/app-search/api/crawler_domain.rb +54 -0
  34. data/lib/elastic/app-search/api/crawler_domain_validation_result.rb +48 -0
  35. data/lib/elastic/app-search/api/crawler_metrics.rb +48 -0
  36. data/lib/elastic/app-search/api/crawler_overview.rb +51 -0
  37. data/lib/elastic/app-search/api/crawler_process_crawl.rb +54 -0
  38. data/lib/elastic/app-search/api/crawler_process_crawl_denied_urls.rb +54 -0
  39. data/lib/elastic/app-search/api/crawler_url_extraction_result.rb +52 -0
  40. data/lib/elastic/app-search/api/crawler_url_tracing_result.rb +52 -0
  41. data/lib/elastic/app-search/api/crawler_url_validation_result.rb +52 -0
  42. data/lib/elastic/app-search/api/crawler_user_agent.rb +48 -0
  43. data/lib/elastic/app-search/api/create_api_key.rb +57 -0
  44. data/lib/elastic/app-search/api/create_crawler_crawl_request.rb +51 -0
  45. data/lib/elastic/app-search/api/create_crawler_crawl_rule.rb +59 -0
  46. data/lib/elastic/app-search/api/create_crawler_domain.rb +55 -0
  47. data/lib/elastic/app-search/api/create_crawler_entry_point.rb +56 -0
  48. data/lib/elastic/app-search/api/create_crawler_process_crawl.rb +53 -0
  49. data/lib/elastic/app-search/api/create_crawler_sitemap.rb +56 -0
  50. data/lib/elastic/app-search/api/create_curation.rb +7 -6
  51. data/lib/elastic/app-search/api/create_engine.rb +9 -7
  52. data/lib/elastic/app-search/api/create_synonym_set.rb +7 -4
  53. data/lib/elastic/app-search/api/curation.rb +4 -3
  54. data/lib/elastic/app-search/api/delete_active_crawl_request.rb +51 -0
  55. data/lib/elastic/app-search/api/delete_api_key.rb +52 -0
  56. data/lib/elastic/app-search/api/delete_crawler_active_crawl_request.rb +51 -0
  57. data/lib/elastic/app-search/api/delete_crawler_crawl_rule.rb +57 -0
  58. data/lib/elastic/app-search/api/delete_crawler_crawl_schedule.rb +51 -0
  59. data/lib/elastic/app-search/api/delete_crawler_domain.rb +54 -0
  60. data/lib/elastic/app-search/api/delete_crawler_entry_point.rb +57 -0
  61. data/lib/elastic/app-search/api/delete_crawler_sitemap.rb +57 -0
  62. data/lib/elastic/app-search/api/delete_curation.rb +4 -3
  63. data/lib/elastic/app-search/api/delete_documents.rb +2 -1
  64. data/lib/elastic/app-search/api/delete_engine.rb +3 -2
  65. data/lib/elastic/app-search/api/delete_meta_engine_source.rb +3 -3
  66. data/lib/elastic/app-search/api/delete_synonym_set.rb +4 -3
  67. data/lib/elastic/app-search/api/denied_urls.rb +54 -0
  68. data/lib/elastic/app-search/api/documents.rb +3 -2
  69. data/lib/elastic/app-search/api/engine.rb +3 -2
  70. data/lib/elastic/app-search/api/index_documents.rb +3 -2
  71. data/lib/elastic/app-search/api/list_api_keys.rb +50 -0
  72. data/lib/elastic/app-search/api/list_crawler_crawl_requests.rb +52 -0
  73. data/lib/elastic/app-search/api/list_crawler_process_crawls.rb +51 -0
  74. data/lib/elastic/app-search/api/list_curations.rb +3 -2
  75. data/lib/elastic/app-search/api/list_documents.rb +3 -2
  76. data/lib/elastic/app-search/api/list_engines.rb +2 -1
  77. data/lib/elastic/app-search/api/list_synonym_sets.rb +3 -2
  78. data/lib/elastic/app-search/api/log_clickthrough.rb +8 -10
  79. data/lib/elastic/app-search/api/put_api_key.rb +59 -0
  80. data/lib/elastic/app-search/api/put_crawler_crawl_rule.rb +62 -0
  81. data/lib/elastic/app-search/api/put_crawler_crawl_schedule.rb +53 -0
  82. data/lib/elastic/app-search/api/put_crawler_domain.rb +58 -0
  83. data/lib/elastic/app-search/api/put_crawler_entry_point.rb +59 -0
  84. data/lib/elastic/app-search/api/put_crawler_sitemap.rb +59 -0
  85. data/lib/elastic/app-search/api/put_curation.rb +9 -8
  86. data/lib/elastic/app-search/api/put_documents.rb +3 -3
  87. data/lib/elastic/app-search/api/put_schema.rb +4 -4
  88. data/lib/elastic/app-search/api/put_search_settings.rb +6 -2
  89. data/lib/elastic/app-search/api/put_synonym_set.rb +8 -5
  90. data/lib/elastic/app-search/api/query_suggestion.rb +7 -7
  91. data/lib/elastic/app-search/api/reset_search_settings.rb +3 -2
  92. data/lib/elastic/app-search/api/schema.rb +3 -2
  93. data/lib/elastic/app-search/api/search.rb +14 -3
  94. data/lib/elastic/app-search/api/search_settings.rb +3 -2
  95. data/lib/elastic/app-search/api/synonym_set.rb +4 -3
  96. data/lib/elastic/app-search/api/top_clicks_analytics.rb +8 -8
  97. data/lib/elastic/app-search/api/top_queries_analytics.rb +7 -7
  98. data/lib/elastic/app-search/app_search.rb +0 -10
  99. data/lib/elastic/enterprise-search/api/health.rb +1 -0
  100. data/lib/elastic/enterprise-search/api/put_read_only.rb +3 -0
  101. data/lib/elastic/enterprise-search/api/read_only.rb +1 -0
  102. data/lib/elastic/enterprise-search/api/version.rb +1 -0
  103. data/lib/elastic/enterprise-search/client.rb +0 -16
  104. data/lib/elastic/enterprise-search/request.rb +14 -3
  105. data/lib/elastic/enterprise-search/version.rb +1 -1
  106. data/lib/elastic/enterprise_search.rb +11 -0
  107. data/lib/elastic/workplace-search/api/auto_query_refinement_details.rb +49 -0
  108. data/lib/elastic/workplace-search/api/command_sync_jobs.rb +53 -0
  109. data/lib/elastic/workplace-search/api/content_source.rb +49 -0
  110. data/lib/elastic/workplace-search/api/create_analytics_event.rb +8 -8
  111. data/lib/elastic/workplace-search/api/create_batch_synonym_sets.rb +50 -0
  112. data/lib/elastic/workplace-search/api/create_content_source.rb +55 -0
  113. data/lib/elastic/workplace-search/api/create_external_identity.rb +3 -1
  114. data/lib/elastic/workplace-search/api/current_user.rb +47 -0
  115. data/lib/elastic/workplace-search/api/delete_all_documents.rb +49 -0
  116. data/lib/elastic/workplace-search/api/delete_content_source.rb +49 -0
  117. data/lib/elastic/workplace-search/api/delete_documents.rb +1 -1
  118. data/lib/elastic/workplace-search/api/delete_documents_by_query.rb +50 -0
  119. data/lib/elastic/workplace-search/api/delete_synonym_set.rb +51 -0
  120. data/lib/elastic/workplace-search/api/document.rb +53 -0
  121. data/lib/elastic/workplace-search/api/list_content_sources.rb +48 -0
  122. data/lib/elastic/workplace-search/api/list_synonym_sets.rb +51 -0
  123. data/lib/elastic/workplace-search/api/put_content_source.rb +58 -0
  124. data/lib/elastic/workplace-search/api/put_content_source_icons.rb +53 -0
  125. data/lib/elastic/workplace-search/api/put_external_identity.rb +3 -1
  126. data/lib/elastic/workplace-search/api/put_synonym_set.rb +53 -0
  127. data/lib/elastic/workplace-search/api/put_triggers_blocklist.rb +47 -0
  128. data/lib/elastic/workplace-search/api/search.rb +4 -1
  129. data/lib/elastic/workplace-search/api/synonym_set.rb +51 -0
  130. data/lib/elastic/workplace-search/api/triggers_blocklist.rb +45 -0
  131. data/lib/elastic/workplace-search/workplace_search.rb +0 -10
  132. data/rake_tasks/unified_release_tasks.rake +46 -0
  133. data/spec/enterprise-search/client_spec.rb +0 -1
  134. data/spec/enterprise-search/request_spec.rb +26 -0
  135. data/spec/integration/app-search/api_key_spec.rb +110 -0
  136. data/spec/integration/app-search/api_logs_spec.rb +59 -0
  137. data/spec/integration/app-search/app_search_helper.rb +39 -0
  138. data/spec/integration/app-search/count_analytics_spec.rb +47 -0
  139. data/spec/integration/app-search/crawl_requests_spec.rb +86 -0
  140. data/spec/integration/app-search/crawler_crawl_rule_spec.rb +73 -0
  141. data/spec/integration/app-search/crawler_domain_spec.rb +82 -0
  142. data/spec/integration/app-search/crawler_entry_point_spec.rb +89 -0
  143. data/spec/integration/app-search/crawler_metrics_spec.rb +46 -0
  144. data/spec/integration/app-search/crawler_overview_spec.rb +45 -0
  145. data/spec/integration/app-search/crawler_process_crawl_denied_urls_spec.rb +50 -0
  146. data/spec/integration/app-search/crawler_process_crawl_spec.rb +66 -0
  147. data/spec/integration/app-search/crawler_scheduling_spec.rb +81 -0
  148. data/spec/integration/app-search/crawler_sitemap_spec.rb +72 -0
  149. data/spec/integration/app-search/crawler_urls_spec.rb +60 -0
  150. data/spec/{app-search/api_count_analytics_spec.rb → integration/app-search/crawler_user_agent_spec.rb} +6 -9
  151. data/spec/integration/app-search/curations_spec.rb +118 -0
  152. data/spec/integration/app-search/documents_spec.rb +123 -0
  153. data/spec/integration/app-search/engines_spec.rb +77 -0
  154. data/spec/{app-search/api_log_clickthrough_spec.rb → integration/app-search/log_clickthrough_spec.rb} +14 -7
  155. data/spec/integration/app-search/meta_engines_spec.rb +75 -0
  156. data/spec/integration/app-search/query_suggestion_spec.rb +50 -0
  157. data/spec/{app-search/api_schema_spec.rb → integration/app-search/schema_spec.rb} +21 -16
  158. data/spec/integration/app-search/search_and_multiple_search_spec.rb +67 -0
  159. data/spec/integration/app-search/search_settings_spec.rb +87 -0
  160. data/spec/integration/app-search/synonyms_spec.rb +79 -0
  161. data/spec/{app-search/api_top_clicks_analytics_spec.rb → integration/app-search/top_clicks_analytics_spec.rb} +20 -14
  162. data/spec/{app-search/api_top_queries_analytics_spec.rb → integration/app-search/top_queries_analytics_spec.rb} +16 -8
  163. data/spec/integration/enterprise_search_api_spec.rb +4 -0
  164. data/spec/integration/workplace-search/content_sources_spec.rb +106 -0
  165. data/spec/integration/workplace-search/documents_spec.rb +95 -0
  166. data/spec/{workplace-search → integration/workplace-search}/external_identities_spec.rb +37 -24
  167. data/spec/integration/workplace-search/icon.png +0 -0
  168. data/spec/integration/workplace-search/permissions_spec.rb +77 -0
  169. data/spec/integration/workplace-search/synonym_sets_spec.rb +92 -0
  170. data/spec/integration/workplace-search/triggers_spec.rb +43 -0
  171. data/spec/{app-search/api_query_suggestion_spec.rb → integration/workplace-search/users_spec.rb} +12 -15
  172. data/spec/integration/workplace-search/workplace_search_helper.rb +39 -0
  173. data/spec/webmock_requires.rb +16 -0
  174. data/spec/workplace-search/client_spec.rb +24 -2
  175. metadata +112 -83
  176. data/.ci/jobs/elastic+enterprise-search-ruby+master.yml +0 -12
  177. data/spec/app-search/api_curations_spec.rb +0 -97
  178. data/spec/app-search/api_documents_spec.rb +0 -102
  179. data/spec/app-search/api_engines_spec.rb +0 -67
  180. data/spec/app-search/api_meta_engines_spec.rb +0 -72
  181. data/spec/app-search/api_search_and_multi_search_spec.rb +0 -48
  182. data/spec/app-search/api_search_settings_spec.rb +0 -76
  183. data/spec/app-search/api_spec_helper.rb +0 -14
  184. data/spec/app-search/api_synonyms_spec.rb +0 -79
  185. data/spec/fixtures/vcr/app_search/add_meta_engine_source.yml +0 -109
  186. data/spec/fixtures/vcr/app_search/api_documents.yml +0 -56
  187. data/spec/fixtures/vcr/app_search/api_index_documents.yml +0 -57
  188. data/spec/fixtures/vcr/app_search/api_log_clickthrough.yml +0 -54
  189. data/spec/fixtures/vcr/app_search/api_logs.yml +0 -70
  190. data/spec/fixtures/vcr/app_search/api_put_schema.yml +0 -109
  191. data/spec/fixtures/vcr/app_search/api_put_search_settings.yml +0 -56
  192. data/spec/fixtures/vcr/app_search/api_query_suggestion.yml +0 -59
  193. data/spec/fixtures/vcr/app_search/api_reset_search_settings.yml +0 -56
  194. data/spec/fixtures/vcr/app_search/api_schema.yml +0 -56
  195. data/spec/fixtures/vcr/app_search/api_search_settings.yml +0 -56
  196. data/spec/fixtures/vcr/app_search/api_top_clicks_analytics.yml +0 -55
  197. data/spec/fixtures/vcr/app_search/api_top_clicks_analytics_query.yml +0 -55
  198. data/spec/fixtures/vcr/app_search/api_top_queries_analytics.yml +0 -55
  199. data/spec/fixtures/vcr/app_search/count_analytics.yml +0 -55
  200. data/spec/fixtures/vcr/app_search/create_and_update_document.yml +0 -107
  201. data/spec/fixtures/vcr/app_search/create_curation.yml +0 -113
  202. data/spec/fixtures/vcr/app_search/create_engine.yml +0 -55
  203. data/spec/fixtures/vcr/app_search/create_meta_engine.yml +0 -56
  204. data/spec/fixtures/vcr/app_search/create_synonym_set.yml +0 -56
  205. data/spec/fixtures/vcr/app_search/delete_curation.yml +0 -56
  206. data/spec/fixtures/vcr/app_search/delete_engine.yml +0 -55
  207. data/spec/fixtures/vcr/app_search/delete_meta_engine_source.yml +0 -56
  208. data/spec/fixtures/vcr/app_search/delete_synonym_set.yml +0 -56
  209. data/spec/fixtures/vcr/app_search/get_curation.yml +0 -56
  210. data/spec/fixtures/vcr/app_search/get_engine.yml +0 -55
  211. data/spec/fixtures/vcr/app_search/index_and_delete_document.yml +0 -107
  212. data/spec/fixtures/vcr/app_search/list_curations.yml +0 -56
  213. data/spec/fixtures/vcr/app_search/list_documents.yml +0 -57
  214. data/spec/fixtures/vcr/app_search/list_engines.yml +0 -55
  215. data/spec/fixtures/vcr/app_search/list_synonym_sets.yml +0 -56
  216. data/spec/fixtures/vcr/app_search/multi_query_search.yml +0 -63
  217. data/spec/fixtures/vcr/app_search/put_curation.yml +0 -113
  218. data/spec/fixtures/vcr/app_search/put_synonym_set.yml +0 -56
  219. data/spec/fixtures/vcr/app_search/search.yml +0 -57
  220. data/spec/fixtures/vcr/app_search/single_query_search.yml +0 -60
  221. data/spec/fixtures/vcr/app_search/synonym_set.yml +0 -56
  222. data/spec/fixtures/vcr/workplace_search/add_user_permissions.yml +0 -53
  223. data/spec/fixtures/vcr/workplace_search/clear_user_permissions.yml +0 -53
  224. data/spec/fixtures/vcr/workplace_search/create_external_identity.yml +0 -53
  225. data/spec/fixtures/vcr/workplace_search/delete_documents.yml +0 -53
  226. data/spec/fixtures/vcr/workplace_search/delete_external_identity.yml +0 -53
  227. data/spec/fixtures/vcr/workplace_search/index_documents.yml +0 -55
  228. data/spec/fixtures/vcr/workplace_search/list_external_identities.yml +0 -53
  229. data/spec/fixtures/vcr/workplace_search/list_permissions.yml +0 -53
  230. data/spec/fixtures/vcr/workplace_search/put_external_identity.yml +0 -53
  231. data/spec/fixtures/vcr/workplace_search/put_user_permissions.yml +0 -103
  232. data/spec/fixtures/vcr/workplace_search/remove_user_permissions.yml +0 -53
  233. data/spec/fixtures/vcr/workplace_search/retrieve_external_identity.yml +0 -53
  234. data/spec/fixtures/vcr/workplace_search/user_permissions_empty.yml +0 -53
  235. data/spec/workplace-search/documents_spec.rb +0 -80
  236. data/spec/workplace-search/permissions_spec.rb +0 -136
@@ -0,0 +1,81 @@
1
+ # Licensed to Elasticsearch B.V. under one or more contributor
2
+ # license agreements. See the NOTICE file distributed with
3
+ # this work for additional information regarding copyright
4
+ # ownership. Elasticsearch B.V. licenses this file to you under
5
+ # the Apache License, Version 2.0 (the "License"); you may
6
+ # not use this file except in compliance with the License.
7
+ # You may obtain a copy of the License at
8
+ #
9
+ # http://www.apache.org/licenses/LICENSE-2.0
10
+ #
11
+ # Unless required by applicable law or agreed to in writing,
12
+ # software distributed under the License is distributed on an
13
+ # "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
14
+ # KIND, either express or implied. See the License for the
15
+ # specific language governing permissions and limitations
16
+ # under the License.
17
+
18
+ # frozen_string_literal: true
19
+
20
+ require_relative "#{__dir__}/app_search_helper.rb"
21
+
22
+ describe Elastic::EnterpriseSearch::AppSearch::Client do
23
+ context 'Crawler scheduling' do
24
+ let(:engine_name) { 'crawler-scheduling' }
25
+ let(:body) { { frequency: 1, unit: 'day' } }
26
+ let(:name) { 'https://www.elastic.co' }
27
+
28
+ before do
29
+ attempts = 0
30
+ loop do
31
+ attempts += 1
32
+ client.create_engine(name: engine_name)
33
+ break if attempts > 9
34
+ rescue Elasticsearch::Transport::Transport::Errors::BadRequest => e
35
+ if e.message.match?(/Name is already taken/)
36
+ sleep 1
37
+ next
38
+ end
39
+ else
40
+ break
41
+ end
42
+ body = { name: name }
43
+ response = client.create_crawler_domain(engine_name, body: body)
44
+ @domain = response.body
45
+ end
46
+
47
+ after do
48
+ client.delete_engine(engine_name)
49
+ end
50
+
51
+ it 'sets a crawl schedule' do
52
+ response = client.put_crawler_crawl_schedule(engine_name, body: body)
53
+ expect(response.status).to eq 200
54
+ expect(response.body).to eq({
55
+ 'engine' => engine_name,
56
+ 'frequency' => 1,
57
+ 'unit' => 'day'
58
+ })
59
+ end
60
+
61
+ it 'gets the crawl schedule' do
62
+ client.put_crawler_crawl_schedule(engine_name, body: body)
63
+
64
+ response = client.crawler_crawl_schedule(engine_name)
65
+ expect(response.status).to eq 200
66
+ expect(response.body).to eq({
67
+ 'engine' => engine_name,
68
+ 'frequency' => 1,
69
+ 'unit' => 'day'
70
+ })
71
+ end
72
+
73
+ it 'deletes a crawler crawl schedule' do
74
+ client.put_crawler_crawl_schedule(engine_name, body: body)
75
+
76
+ response = client.delete_crawler_crawl_schedule(engine_name)
77
+ expect(response.status).to eq 200
78
+ expect(response.body).to eq({ 'deleted' => true })
79
+ end
80
+ end
81
+ end
@@ -0,0 +1,72 @@
1
+ # Licensed to Elasticsearch B.V. under one or more contributor
2
+ # license agreements. See the NOTICE file distributed with
3
+ # this work for additional information regarding copyright
4
+ # ownership. Elasticsearch B.V. licenses this file to you under
5
+ # the Apache License, Version 2.0 (the "License"); you may
6
+ # not use this file except in compliance with the License.
7
+ # You may obtain a copy of the License at
8
+ #
9
+ # http://www.apache.org/licenses/LICENSE-2.0
10
+ #
11
+ # Unless required by applicable law or agreed to in writing,
12
+ # software distributed under the License is distributed on an
13
+ # "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
14
+ # KIND, either express or implied. See the License for the
15
+ # specific language governing permissions and limitations
16
+ # under the License.
17
+
18
+ # frozen_string_literal: true
19
+
20
+ require_relative "#{__dir__}/app_search_helper.rb"
21
+
22
+ describe Elastic::EnterpriseSearch::AppSearch::Client do
23
+ context 'Crawler Sitemap' do
24
+ let(:engine_name) { 'crawler-sitemap' }
25
+ let(:name) { 'https://www.elastic.co' }
26
+
27
+ before do
28
+ client.create_engine(name: engine_name)
29
+ body = { name: name }
30
+ response = client.create_crawler_domain(engine_name, body: body)
31
+ @domain = response.body
32
+ end
33
+
34
+ after do
35
+ client.delete_engine(engine_name)
36
+ end
37
+
38
+ it 'creates, updates and deletes a crawler sitemap configuration' do
39
+ # Create a sitemap
40
+ sitemap_url = 'https://www.elastic.co/sitemap.xml'
41
+ body = { url: sitemap_url }
42
+ response = client.create_crawler_sitemap(engine_name, domain_id: @domain['id'], body: body)
43
+ expect(response.status).to eq 200
44
+ expect(response.body.keys).to eq(['id', 'url', 'created_at'])
45
+ expect(response.body['url']).to eq(sitemap_url)
46
+
47
+ # Update a sitemap
48
+ sitemap_id = response.body['id']
49
+ sitemap_url = 'https://www.elastic.co/sitemap2.xml'
50
+ body = { url: sitemap_url }
51
+ response = client.put_crawler_sitemap(
52
+ engine_name,
53
+ domain_id: @domain['id'],
54
+ sitemap_id: sitemap_id,
55
+ body: body
56
+ )
57
+ expect(response.status).to eq 200
58
+ expect(response.body.keys).to eq(['id', 'url', 'created_at'])
59
+ expect(response.body['url']).to eq(sitemap_url)
60
+
61
+ # Delete sitemap
62
+ response = client.delete_crawler_sitemap(
63
+ engine_name,
64
+ domain_id: @domain['id'],
65
+ sitemap_id: sitemap_id
66
+ )
67
+
68
+ expect(response.status).to eq 200
69
+ expect(response.body).to eq({ 'deleted' => true })
70
+ end
71
+ end
72
+ end
@@ -0,0 +1,60 @@
1
+ # Licensed to Elasticsearch B.V. under one or more contributor
2
+ # license agreements. See the NOTICE file distributed with
3
+ # this work for additional information regarding copyright
4
+ # ownership. Elasticsearch B.V. licenses this file to you under
5
+ # the Apache License, Version 2.0 (the "License"); you may
6
+ # not use this file except in compliance with the License.
7
+ # You may obtain a copy of the License at
8
+ #
9
+ # http://www.apache.org/licenses/LICENSE-2.0
10
+ #
11
+ # Unless required by applicable law or agreed to in writing,
12
+ # software distributed under the License is distributed on an
13
+ # "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
14
+ # KIND, either express or implied. See the License for the
15
+ # specific language governing permissions and limitations
16
+ # under the License.
17
+
18
+ # frozen_string_literal: true
19
+
20
+ require_relative "#{__dir__}/app_search_helper.rb"
21
+
22
+ describe Elastic::EnterpriseSearch::AppSearch::Client do
23
+ context 'Crawler URLs' do
24
+ let(:engine_name) { 'crawler-urls' }
25
+ let(:name) { 'https://www.elastic.co' }
26
+
27
+ before do
28
+ client.create_engine(name: engine_name)
29
+ body = { name: name }
30
+ response = client.create_crawler_domain(engine_name, body: body)
31
+ @domain = response.body
32
+ end
33
+
34
+ after do
35
+ client.delete_engine(engine_name)
36
+ sleep 1
37
+ end
38
+
39
+ it 'validates a URL' do
40
+ response = client.crawler_url_validation_result(engine_name, url: name)
41
+ expect(response.status).to eq 200
42
+ expect(response.body['url']).to eq name
43
+ expect(response.body['valid']).to eq true
44
+ end
45
+
46
+ it 'extracts content from a URL' do
47
+ response = client.crawler_url_extraction_result(engine_name, url: name)
48
+ expect(response.status).to eq 200
49
+ expect(response.body.keys).to eq(['url', 'normalized_url', 'results'])
50
+ end
51
+
52
+ it 'traces history for a crawler URL' do
53
+ response = client.crawler_url_tracing_result(engine_name, url: name)
54
+ expect(response.status).to eq 200
55
+ expect(response.body['url']).to eq name
56
+ expect(response.body['normalized_url']).to eq "#{name}/"
57
+ expect(response.body['crawl_requests'])
58
+ end
59
+ end
60
+ end
@@ -17,18 +17,15 @@
17
17
 
18
18
  # frozen_string_literal: true
19
19
 
20
- require 'spec_helper'
21
- require_relative './api_spec_helper'
20
+ require_relative "#{__dir__}/app_search_helper.rb"
22
21
 
23
22
  describe Elastic::EnterpriseSearch::AppSearch::Client do
24
- context 'api_logs' do
25
- it 'returns api logs' do
26
- VCR.use_cassette('app_search/count_analytics') do
27
- response = @client.count_analytics('videogames')
23
+ context 'Crawler User Agent' do
24
+ it 'retrieves the user-agent header value for the crawler' do
25
+ response = client.crawler_user_agent
28
26
 
29
- expect(response.status).to eq 200
30
- expect(response.body['results'].count).to be > 1
31
- end
27
+ expect(response.status).to eq 200
28
+ expect(response.body['user_agent']).to match(/Elastic-Crawler\ \([0-9.]+\)/)
32
29
  end
33
30
  end
34
31
  end
@@ -0,0 +1,118 @@
1
+ # Licensed to Elasticsearch B.V. under one or more contributor
2
+ # license agreements. See the NOTICE file distributed with
3
+ # this work for additional information regarding copyright
4
+ # ownership. Elasticsearch B.V. licenses this file to you under
5
+ # the Apache License, Version 2.0 (the "License"); you may
6
+ # not use this file except in compliance with the License.
7
+ # You may obtain a copy of the License at
8
+ #
9
+ # http://www.apache.org/licenses/LICENSE-2.0
10
+ #
11
+ # Unless required by applicable law or agreed to in writing,
12
+ # software distributed under the License is distributed on an
13
+ # "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
14
+ # KIND, either express or implied. See the License for the
15
+ # specific language governing permissions and limitations
16
+ # under the License.
17
+
18
+ # frozen_string_literal: true
19
+
20
+ require_relative "#{__dir__}/app_search_helper.rb"
21
+
22
+ describe Elastic::EnterpriseSearch::AppSearch::Client do
23
+ context 'Curations' do
24
+ let(:engine_name) { 'books' }
25
+
26
+ before do
27
+ client.create_engine(name: engine_name)
28
+ documents = [
29
+ { title: 'Jungle Tales', author: 'Horacio Quiroga' },
30
+ { title: 'The Jungle Book', author: 'Rudyard Kipling' }
31
+ ]
32
+ response = client.index_documents(engine_name, documents: documents)
33
+
34
+ @promoted = response.body.first
35
+ @hidden = response.body.last
36
+ end
37
+ after do
38
+ client.delete_engine(engine_name)
39
+ sleep 1
40
+ end
41
+
42
+ it 'creates a new curation' do
43
+ response = create_curation(engine_name, 'jungle', @promoted['id'], @hidden['id'])
44
+ expect(response.status).to eq 200
45
+ expect(response.body['id']).to match(/cur-[0-9a-f]+/)
46
+
47
+ response = client.search(engine_name, query: 'jungle')
48
+ expect(response.status).to eq 200
49
+ expect(response.body['results'].count).to eq 1
50
+ expect(response.body['results'].first['title']['raw']).to eq 'Jungle Tales'
51
+ end
52
+
53
+ it 'retrieves a curation by id' do
54
+ id = create_curation(engine_name, 'book', @promoted['id'], @hidden['id']).body['id']
55
+
56
+ response = client.curation(engine_name, curation_id: id)
57
+
58
+ expect(response.status).to eq 200
59
+ expect(response.body['id']).to match(/cur-[0-9a-f]+/)
60
+ expect(response.body['queries']).to eq ['book']
61
+ expect(response.body['promoted']).to eq [@promoted['id']]
62
+ expect(response.body['hidden']).to eq [@hidden['id']]
63
+ end
64
+
65
+ def create_curation(name, query, promoted_id, hidden_id)
66
+ response = client.create_curation(
67
+ name,
68
+ queries: [query],
69
+ promoted: [promoted_id],
70
+ hidden: [hidden_id]
71
+ )
72
+ # Give the server a second
73
+ sleep 1
74
+ response
75
+ end
76
+
77
+ it 'updates an existing curation' do
78
+ id = create_curation(engine_name, 'jungle', @promoted['id'], @hidden['id']).body['id']
79
+
80
+ response = client.put_curation(
81
+ engine_name,
82
+ curation_id: id,
83
+ queries: ['jungle'],
84
+ promoted: [@hidden['id']],
85
+ hidden: [@promoted['id']]
86
+ )
87
+
88
+ expect(response.status).to eq 200
89
+ expect(response.body['id']).to match(/cur-[0-9a-f]+/)
90
+
91
+ response = @client.search(engine_name, query: 'jungle')
92
+ expect(response.status).to eq 200
93
+ expect(response.body['results'].count).to eq 1
94
+ expect(response.body['results'].first['title']['raw']).to eq 'The Jungle Book'
95
+ end
96
+
97
+ it 'lists curations' do
98
+ create_curation(engine_name, 'jungle', @promoted['id'], @hidden['id']).body['id']
99
+ create_curation(engine_name, 'book', @promoted['id'], @hidden['id']).body['id']
100
+ create_curation(engine_name, 'tales', @promoted['id'], @hidden['id']).body['id']
101
+
102
+ response = client.list_curations(engine_name)
103
+
104
+ expect(response.status).to eq 200
105
+ expect(response.body['results'].count).to eq 3
106
+ curation = response.body['results'].first
107
+ expect(curation['id']).to match(/cur-[0-9a-f]+/)
108
+ end
109
+
110
+ it 'deletes a curation' do
111
+ id = create_curation(engine_name, 'jungle', @promoted['id'], @hidden['id']).body['id']
112
+ response = client.delete_curation(engine_name, curation_id: id)
113
+
114
+ expect(response.status).to eq 200
115
+ expect(response.body).to eq({ 'deleted' => true })
116
+ end
117
+ end
118
+ end
@@ -0,0 +1,123 @@
1
+ # Licensed to Elasticsearch B.V. under one or more contributor
2
+ # license agreements. See the NOTICE file distributed with
3
+ # this work for additional information regarding copyright
4
+ # ownership. Elasticsearch B.V. licenses this file to you under
5
+ # the Apache License, Version 2.0 (the "License"); you may
6
+ # not use this file except in compliance with the License.
7
+ # You may obtain a copy of the License at
8
+ #
9
+ # http://www.apache.org/licenses/LICENSE-2.0
10
+ #
11
+ # Unless required by applicable law or agreed to in writing,
12
+ # software distributed under the License is distributed on an
13
+ # "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
14
+ # KIND, either express or implied. See the License for the
15
+ # specific language governing permissions and limitations
16
+ # under the License.
17
+
18
+ # frozen_string_literal: true
19
+
20
+ require_relative "#{__dir__}/app_search_helper.rb"
21
+
22
+ describe Elastic::EnterpriseSearch::AppSearch::Client do
23
+ context 'documents' do
24
+ let(:engine_name) { 'documents' }
25
+ let(:documents) do
26
+ [
27
+ { name: 'Super Lorenzo Bros', year: '1985' },
28
+ { name: 'Pack-Man', year: '1980' },
29
+ { name: 'Galaxxian', year: '1979' },
30
+ { name: 'Audiovisual, the hedgehog', year: '1991' }
31
+ ]
32
+ end
33
+
34
+ before do
35
+ client.create_engine(name: engine_name)
36
+ end
37
+
38
+ after do
39
+ delete_engines
40
+ end
41
+
42
+ def extract_from_key(key)
43
+ ->(h) { h[key] }
44
+ end
45
+
46
+ it 'indexes and lists documents' do
47
+ response = client.index_documents(engine_name, documents: documents)
48
+ expect(response.status).to eq 200
49
+ expect(response.body.count).to eq 4
50
+ expect(response.body.map(&:keys)).to eq [['id', 'errors'], ['id', 'errors'], ['id', 'errors'], ['id', 'errors']]
51
+
52
+ response = client.list_documents(engine_name)
53
+ attempts = 0
54
+ while response.body['results'].count < 1 && attempts < 20
55
+ sleep 1
56
+ attempts += 1
57
+ response = client.list_documents(engine_name)
58
+ end
59
+
60
+ expect(response.status).to eq 200
61
+ expect(response.body['results'].count).to eq 4
62
+ end
63
+
64
+ it 'retrieves documents by ID' do
65
+ response = client.index_documents(engine_name, documents: documents)
66
+ ids = response.body.map(&->(h) { h['id'] })
67
+
68
+ attempts = 0
69
+ while client.list_documents(engine_name).body['results'].count < 4 && attempts < 20
70
+ sleep 1
71
+ attempts += 1
72
+ end
73
+
74
+ response = client.documents(engine_name, document_ids: ids)
75
+
76
+ expect(response.status).to eq 200
77
+ expect(response.body.count).to eq 4
78
+ expect(
79
+ response.body.map(&extract_from_key('name')) - documents.map(&extract_from_key(:name))
80
+ ).to be_empty
81
+ end
82
+
83
+ it 'searches for a document' do
84
+ client.index_documents(engine_name, documents: documents)
85
+
86
+ response = client.search(engine_name, body: { query: 'Pack-Man' })
87
+ attempts = 0
88
+ while response.body['results'].count < 1 && attempts < 20
89
+ sleep 1
90
+ attempts += 1
91
+ response = client.search(engine_name, body: { query: 'Pack-Man' })
92
+ end
93
+ expect(response.status).to eq 200
94
+ expect(response.body['meta']['engine']).to eq({ 'name' => engine_name, 'type' => 'default' })
95
+ expect(response.body['results'].first['name']).to eq({ 'raw' => 'Pack-Man' })
96
+ expect(response.body['results'].first['year']).to eq({ 'raw' => '1980' })
97
+ end
98
+
99
+ it 'deletes a document' do
100
+ document = { name: 'Celda', year: 1986 }
101
+ response = client.index_documents(engine_name, documents: document)
102
+ expect(response.status).to eq 200
103
+
104
+ id = response.body.first['id']
105
+
106
+ response = client.delete_documents(engine_name, document_ids: [id])
107
+ expect(response.status).to eq 200
108
+ expect(response.body.first['deleted'])
109
+ end
110
+
111
+ it 'updates a document' do
112
+ document = { name: 'Al*bert', year: 1983 }
113
+ response = client.index_documents(engine_name, documents: document)
114
+ expect(response.status).to eq 200
115
+
116
+ id = response.body.first['id']
117
+
118
+ response = client.put_documents(engine_name, documents: [{ id: id, year: 1982 }])
119
+ expect(response.status).to eq 200
120
+ expect(response.body).to eq [{ 'id' => id, 'errors' => [] }]
121
+ end
122
+ end
123
+ end
@@ -0,0 +1,77 @@
1
+ # Licensed to Elasticsearch B.V. under one or more contributor
2
+ # license agreements. See the NOTICE file distributed with
3
+ # this work for additional information regarding copyright
4
+ # ownership. Elasticsearch B.V. licenses this file to you under
5
+ # the Apache License, Version 2.0 (the "License"); you may
6
+ # not use this file except in compliance with the License.
7
+ # You may obtain a copy of the License at
8
+ #
9
+ # http://www.apache.org/licenses/LICENSE-2.0
10
+ #
11
+ # Unless required by applicable law or agreed to in writing,
12
+ # software distributed under the License is distributed on an
13
+ # "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
14
+ # KIND, either express or implied. See the License for the
15
+ # specific language governing permissions and limitations
16
+ # under the License.
17
+
18
+ # frozen_string_literal: true
19
+
20
+ require_relative "#{__dir__}/app_search_helper.rb"
21
+
22
+ describe Elastic::EnterpriseSearch::AppSearch::Client do
23
+ context 'Engines' do
24
+ let(:engine_name) { 'test-create-engines' }
25
+
26
+ after do
27
+ delete_engines
28
+ end
29
+
30
+ it 'creates a new engine' do
31
+ response = client.create_engine(name: engine_name)
32
+
33
+ expect(response.status).to eq 200
34
+ expect(response.body).to eq(
35
+ {
36
+ 'name' => engine_name,
37
+ 'type' => 'default',
38
+ 'language' => nil,
39
+ 'document_count' => 0
40
+ }
41
+ )
42
+ end
43
+
44
+ it 'lists engines' do
45
+ client.create_engine(name: 'engine1')
46
+ client.create_engine(name: 'engine2')
47
+
48
+ response = client.list_engines
49
+ expect(response.status).to eq 200
50
+
51
+ expect(response.body.dig('meta', 'page', 'total_results')).to eq 2
52
+ expect(response.body['results']).to include(
53
+ { 'name' => 'engine1', 'type' => 'default', 'language' => nil, 'document_count' => 0 }
54
+ )
55
+ expect(response.body['results']).to include(
56
+ { 'name' => 'engine2', 'type' => 'default', 'language' => nil, 'document_count' => 0 }
57
+ )
58
+ end
59
+
60
+ it 'retrieves an engine by name' do
61
+ client.create_engine(name: engine_name)
62
+ response = client.engine(engine_name)
63
+
64
+ expect(response.status).to eq 200
65
+ expect(response.body).to eq(
66
+ { 'name' => engine_name, 'type' => 'default', 'language' => nil, 'document_count' => 0 }
67
+ )
68
+ end
69
+
70
+ it 'deletes an engine' do
71
+ client.create_engine(name: engine_name)
72
+ response = client.delete_engine(engine_name)
73
+ expect(response.status).to eq 200
74
+ expect(response.body).to eq({ 'deleted' => true })
75
+ end
76
+ end
77
+ end
@@ -17,18 +17,25 @@
17
17
 
18
18
  # frozen_string_literal: true
19
19
 
20
- require_relative './api_spec_helper'
20
+ require_relative "#{__dir__}/app_search_helper.rb"
21
21
 
22
22
  describe Elastic::EnterpriseSearch::AppSearch::Client do
23
- context 'api_log_clickthrough' do
24
- let(:engine_name) { 'films' }
23
+ context 'Log Click through' do
24
+ let(:engine_name) { 'videogames' }
25
+
26
+ before do
27
+ client.create_engine(name: engine_name)
28
+ end
29
+
30
+ after do
31
+ client.delete_engine(engine_name)
32
+ end
25
33
 
26
34
  it 'logs clicked results' do
27
- VCR.use_cassette('app_search/api_log_clickthrough') do
28
- response = @client.log_clickthrough(engine_name, query_text: 'moon', document_id: 'doc-id')
35
+ body = { query: 'moon', document_id: 'doc_id' }
36
+ response = client.log_clickthrough(engine_name, body: body)
29
37
 
30
- expect(response.status).to eq 200
31
- end
38
+ expect(response.status).to eq 200
32
39
  end
33
40
  end
34
41
  end
@@ -0,0 +1,75 @@
1
+ # Licensed to Elasticsearch B.V. under one or more contributor
2
+ # license agreements. See the NOTICE file distributed with
3
+ # this work for additional information regarding copyright
4
+ # ownership. Elasticsearch B.V. licenses this file to you under
5
+ # the Apache License, Version 2.0 (the "License"); you may
6
+ # not use this file except in compliance with the License.
7
+ # You may obtain a copy of the License at
8
+ #
9
+ # http://www.apache.org/licenses/LICENSE-2.0
10
+ #
11
+ # Unless required by applicable law or agreed to in writing,
12
+ # software distributed under the License is distributed on an
13
+ # "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
14
+ # KIND, either express or implied. See the License for the
15
+ # specific language governing permissions and limitations
16
+ # under the License.
17
+
18
+ # frozen_string_literal: true
19
+
20
+ require_relative "#{__dir__}/app_search_helper.rb"
21
+
22
+ describe Elastic::EnterpriseSearch::AppSearch::Client do
23
+ context 'Meta Engines' do
24
+ let(:engine_name) { 'new-meta-engine' }
25
+ let(:create_meta_engine) do
26
+ body = {
27
+ name: engine_name,
28
+ type: 'meta',
29
+ source_engines: ['books', 'videogames']
30
+ }
31
+ client.create_engine(name: engine_name, body: body)
32
+ end
33
+
34
+ before do
35
+ client.create_engine(name: 'books')
36
+ client.create_engine(name: 'videogames')
37
+ end
38
+
39
+ after do
40
+ delete_engines
41
+ end
42
+
43
+ it 'creates a meta engine' do
44
+ response = create_meta_engine
45
+ expect(response.status).to eq 200
46
+ expect(response.body['name']).to eq(engine_name)
47
+ expect(response.body['type']).to eq('meta')
48
+ expect(response.body['source_engines'].sort).to eq(['books', 'videogames'])
49
+ end
50
+
51
+ it 'adds a new source engine to a meta engine' do
52
+ create_meta_engine
53
+ # Create new source engine to add:
54
+ client.create_engine(name: 'add-source')
55
+ response = client.add_meta_engine_source(engine_name, source_engines: ['add-source'])
56
+
57
+ expect(response.status).to eq 200
58
+ expect(response.body['name']).to eq(engine_name)
59
+ expect(response.body['type']).to eq('meta')
60
+ expect(response.body['source_engines'].sort).to eq(['add-source', 'books', 'videogames'])
61
+ end
62
+
63
+ it 'removes a source engine from a meta engine' do
64
+ create_meta_engine
65
+ client.create_engine(name: 'remove-source')
66
+ client.add_meta_engine_source(engine_name, source_engines: ['remove-source'])
67
+ response = client.delete_meta_engine_source(engine_name, source_engines: ['remove-source'])
68
+
69
+ expect(response.status).to eq 200
70
+ expect(response.body['name']).to eq(engine_name)
71
+ expect(response.body['type']).to eq('meta')
72
+ expect(response.body['source_engines'].sort).to eq(['books', 'videogames'])
73
+ end
74
+ end
75
+ end