elastic-enterprise-search 0.3.1 → 7.10.0.beta.1

Sign up to get free protection for your applications and to get access to all the features.
Files changed (162) hide show
  1. checksums.yaml +4 -4
  2. data/.ci/.gitignore +1 -0
  3. data/.ci/Dockerfile +12 -0
  4. data/.ci/certs/README.md +50 -0
  5. data/.ci/certs/ca.crt +20 -0
  6. data/.ci/certs/ca.key +27 -0
  7. data/.ci/certs/testnode.crt +21 -0
  8. data/.ci/certs/testnode.key +27 -0
  9. data/.ci/certs/testnode_no_san.crt +19 -0
  10. data/.ci/certs/testnode_no_san.key +27 -0
  11. data/.ci/functions/cleanup.sh +67 -0
  12. data/.ci/functions/imports.sh +60 -0
  13. data/.ci/functions/wait-for-container.sh +36 -0
  14. data/.ci/jobs/defaults.yml +69 -0
  15. data/.ci/jobs/elastic+enterprise-search-ruby+master.yml +12 -0
  16. data/.ci/jobs/elastic+enterprise-search-ruby+pull-request.yml +19 -0
  17. data/.ci/run-elasticsearch.sh +127 -0
  18. data/.ci/run-enterprise-search.sh +70 -0
  19. data/.ci/run-local.sh +14 -0
  20. data/.ci/run-repository.sh +47 -0
  21. data/.ci/run-tests +29 -0
  22. data/.ci/test-matrix.yml +13 -0
  23. data/.github/workflows/rubocop.yml +15 -0
  24. data/.github/workflows/testing.yml +40 -0
  25. data/.gitignore +3 -0
  26. data/.rubocop.yml +52 -0
  27. data/Gemfile +22 -1
  28. data/{LICENSE.txt → LICENSE} +33 -32
  29. data/README.md +201 -103
  30. data/Rakefile +71 -1
  31. data/elastic-enterprise-search.gemspec +47 -13
  32. data/lib/elastic-enterprise-search.rb +20 -1
  33. data/lib/elastic/.rubocop.yml +6 -0
  34. data/lib/elastic/app-search/api/add_meta_engine_source.rb +48 -0
  35. data/lib/elastic/app-search/api/api_logs.rb +63 -0
  36. data/lib/elastic/app-search/api/count_analytics.rb +50 -0
  37. data/lib/elastic/app-search/api/create_curation.rb +52 -0
  38. data/lib/elastic/app-search/api/create_engine.rb +51 -0
  39. data/lib/elastic/app-search/api/create_synonym_set.rb +50 -0
  40. data/lib/elastic/app-search/api/curation.rb +52 -0
  41. data/lib/elastic/app-search/api/delete_curation.rb +52 -0
  42. data/lib/elastic/app-search/api/delete_documents.rb +48 -0
  43. data/lib/elastic/app-search/api/delete_engine.rb +48 -0
  44. data/lib/elastic/app-search/api/delete_meta_engine_source.rb +48 -0
  45. data/lib/elastic/app-search/api/delete_synonym_set.rb +52 -0
  46. data/lib/elastic/app-search/api/documents.rb +48 -0
  47. data/lib/elastic/app-search/api/engine.rb +48 -0
  48. data/lib/elastic/app-search/api/index_documents.rb +48 -0
  49. data/lib/elastic/app-search/api/list_curations.rb +50 -0
  50. data/lib/elastic/app-search/api/list_documents.rb +50 -0
  51. data/lib/elastic/app-search/api/list_engines.rb +47 -0
  52. data/lib/elastic/app-search/api/list_synonym_sets.rb +50 -0
  53. data/lib/elastic/app-search/api/log_clickthrough.rb +54 -0
  54. data/lib/elastic/app-search/api/multi_search.rb +50 -0
  55. data/lib/elastic/app-search/api/put_curation.rb +56 -0
  56. data/lib/elastic/app-search/api/put_documents.rb +48 -0
  57. data/lib/elastic/app-search/api/put_schema.rb +48 -0
  58. data/lib/elastic/app-search/api/put_search_settings.rb +48 -0
  59. data/lib/elastic/app-search/api/put_synonym_set.rb +54 -0
  60. data/lib/elastic/app-search/api/query_suggestion.rb +52 -0
  61. data/lib/elastic/app-search/api/reset_search_settings.rb +48 -0
  62. data/lib/elastic/app-search/api/schema.rb +48 -0
  63. data/lib/elastic/app-search/api/search.rb +48 -0
  64. data/lib/elastic/app-search/api/search_settings.rb +48 -0
  65. data/lib/elastic/app-search/api/synonym_set.rb +52 -0
  66. data/lib/elastic/app-search/api/top_clicks_analytics.rb +52 -0
  67. data/lib/elastic/app-search/api/top_queries_analytics.rb +51 -0
  68. data/lib/elastic/app-search/app_search.rb +65 -0
  69. data/lib/elastic/enterprise-search/api/health.rb +38 -0
  70. data/lib/elastic/enterprise-search/api/put_read_only.rb +40 -0
  71. data/lib/elastic/enterprise-search/api/read_only.rb +38 -0
  72. data/lib/elastic/enterprise-search/api/stats.rb +41 -0
  73. data/lib/elastic/enterprise-search/api/version.rb +38 -0
  74. data/lib/elastic/enterprise-search/client.rb +79 -15
  75. data/lib/elastic/enterprise-search/configuration.rb +32 -16
  76. data/lib/elastic/enterprise-search/exceptions.rb +19 -0
  77. data/lib/elastic/enterprise-search/request.rb +46 -80
  78. data/lib/elastic/enterprise-search/utils.rb +29 -1
  79. data/lib/elastic/enterprise-search/version.rb +20 -1
  80. data/lib/elastic/enterprise_search.rb +38 -0
  81. data/lib/elastic/workplace-search/api/add_user_permissions.rb +53 -0
  82. data/lib/elastic/workplace-search/api/create_external_identity.rb +49 -0
  83. data/lib/elastic/workplace-search/api/delete_documents.rb +49 -0
  84. data/lib/elastic/workplace-search/api/delete_external_identity.rb +49 -0
  85. data/lib/elastic/workplace-search/api/external_identity.rb +49 -0
  86. data/lib/elastic/workplace-search/api/index_documents.rb +49 -0
  87. data/lib/elastic/workplace-search/api/list_external_identities.rb +47 -0
  88. data/lib/elastic/workplace-search/api/list_permissions.rb +47 -0
  89. data/lib/elastic/workplace-search/api/put_external_identity.rb +53 -0
  90. data/lib/elastic/workplace-search/api/put_user_permissions.rb +53 -0
  91. data/lib/elastic/workplace-search/api/remove_user_permissions.rb +53 -0
  92. data/lib/elastic/workplace-search/api/search.rb +42 -0
  93. data/lib/elastic/workplace-search/api/user_permissions.rb +49 -0
  94. data/lib/elastic/workplace-search/workplace_search.rb +59 -0
  95. data/lib/generator/documentation_helper.rb +94 -0
  96. data/lib/generator/endpoint_generator.rb +119 -0
  97. data/lib/generator/parameters_exceptions.rb +40 -0
  98. data/lib/generator/parameters_helper.rb +144 -0
  99. data/lib/generator/templates/_license.erb +16 -0
  100. data/lib/generator/templates/endpoint_template.erb +29 -0
  101. data/lib/generator/templates/spec_template.erb +1 -0
  102. data/lib/generator/utils.rb +70 -0
  103. data/spec/app-search/api_count_analytics_spec.rb +34 -0
  104. data/spec/app-search/api_documents_spec.rb +88 -0
  105. data/spec/app-search/api_engines_spec.rb +67 -0
  106. data/spec/app-search/api_logs_spec.rb +36 -0
  107. data/spec/app-search/api_schema_spec.rb +34 -0
  108. data/spec/app-search/api_search_and_multi_search_spec.rb +48 -0
  109. data/spec/app-search/api_spec_helper.rb +14 -0
  110. data/spec/app-search/api_top_clicks_analytics_spec.rb +44 -0
  111. data/spec/app-search/api_top_queries_analytics_spec.rb +34 -0
  112. data/spec/app-search/client_spec.rb +68 -0
  113. data/spec/enterprise-search/client_spec.rb +96 -0
  114. data/spec/enterprise-search/request_spec.rb +114 -0
  115. data/spec/fixtures/vcr/add_user_permissions.yml +18 -22
  116. data/spec/fixtures/vcr/app_search/api_logs.yml +70 -0
  117. data/spec/fixtures/vcr/app_search/api_top_clicks_analytics.yml +55 -0
  118. data/spec/fixtures/vcr/app_search/api_top_clicks_analytics_query.yml +55 -0
  119. data/spec/fixtures/vcr/app_search/api_top_queries_analytics.yml +55 -0
  120. data/spec/fixtures/vcr/app_search/count_analytics.yml +55 -0
  121. data/spec/fixtures/vcr/app_search/create_and_update_document.yml +107 -0
  122. data/spec/fixtures/vcr/app_search/index_and_delete_document.yml +107 -0
  123. data/spec/fixtures/vcr/app_search/index_documents.yml +56 -0
  124. data/spec/fixtures/vcr/app_search/list_documents.yml +57 -0
  125. data/spec/fixtures/vcr/app_search/multi_query_search.yml +63 -0
  126. data/spec/fixtures/vcr/app_search/schema.yml +55 -0
  127. data/spec/fixtures/vcr/app_search/search.yml +57 -0
  128. data/spec/fixtures/vcr/app_search/single_query_search.yml +60 -0
  129. data/spec/fixtures/vcr/clear_user_permissions.yml +51 -0
  130. data/spec/fixtures/vcr/create_document.yml +54 -0
  131. data/spec/fixtures/vcr/create_engine.yml +55 -0
  132. data/spec/fixtures/vcr/delete_documents.yml +51 -0
  133. data/spec/fixtures/vcr/delete_engine.yml +55 -0
  134. data/spec/fixtures/vcr/get_engine.yml +55 -0
  135. data/spec/fixtures/vcr/index_documents.yml +53 -0
  136. data/spec/fixtures/vcr/list_engines.yml +55 -0
  137. data/spec/fixtures/vcr/list_permissions.yml +51 -0
  138. data/spec/fixtures/vcr/put_user_permissions.yml +99 -0
  139. data/spec/fixtures/vcr/remove_user_permissions.yml +16 -20
  140. data/spec/fixtures/vcr/user_permissions_empty.yml +51 -0
  141. data/spec/integration/enterprise_search_api_spec.rb +96 -0
  142. data/spec/spec_helper.rb +25 -14
  143. data/spec/webmock_requires.rb +4 -0
  144. data/spec/workplace-search/api_spec.rb +188 -0
  145. data/spec/workplace-search/client_spec.rb +69 -0
  146. metadata +207 -47
  147. data/.circleci/config.yml +0 -68
  148. data/.travis.yml +0 -15
  149. data/NOTICE.txt +0 -3
  150. data/lib/elastic/enterprise-search.rb +0 -7
  151. data/lib/elastic/enterprise-search/client/content_source_documents.rb +0 -46
  152. data/lib/elastic/enterprise-search/client/permissions.rb +0 -30
  153. data/logo-enterprise-search.png +0 -0
  154. data/spec/client/content_source_documents_spec.rb +0 -55
  155. data/spec/client/permissions_spec.rb +0 -75
  156. data/spec/configuration_spec.rb +0 -19
  157. data/spec/fixtures/vcr/async_create_or_update_document_success.yml +0 -51
  158. data/spec/fixtures/vcr/destroy_documents_success.yml +0 -51
  159. data/spec/fixtures/vcr/get_user_permissions.yml +0 -55
  160. data/spec/fixtures/vcr/list_all_permissions.yml +0 -55
  161. data/spec/fixtures/vcr/list_all_permissions_with_paging.yml +0 -55
  162. data/spec/fixtures/vcr/update_user_permissions.yml +0 -55
checksums.yaml CHANGED
@@ -1,7 +1,7 @@
1
1
  ---
2
2
  SHA256:
3
- metadata.gz: 53aa50b909137dfa347b53c771575f37181a4f757e67172cc122fa1d2868146d
4
- data.tar.gz: fd9707d3ac0e26964295251d3cf785e5d3a7bbcb20c5d17c972ee2db5f077cd0
3
+ metadata.gz: 44f9e978a08756f49fb8e41f7e87b456c0eb07f0296f276777502008bce5f6be
4
+ data.tar.gz: 76a990ce960e215850f041bd12facbf1d2d49041957117c2462be861cba49a23
5
5
  SHA512:
6
- metadata.gz: fb1cd040e074c1afe2d7e527fe0024b7f7beb1afb1cee2b56908aa54eb5fef293dc37bf3fae66d53fd4b92eb1e882ea70afadb50c869a387bd57d69a10bb9219
7
- data.tar.gz: 532b1da449b8865a2adb98ee557b89ac986012cef51d9a65ecac28c7ce52a37988b27609de3014ba86e754689d2adc016989f05fda9a91f1d74d62a9e217f1e1
6
+ metadata.gz: 1b794b281d4fe0936f9e8025f8b2f1c7309f31d68bcfbaee43181e983f8a155a359de54b81b70d4eba2bbe581c8f8ea90e66d6b704e99678dbb5f82858a50251
7
+ data.tar.gz: 8c39a543c9a41574a6632148f242ff860077e01f7d52004e82c2224f35e028839b740315fbb1276b7562e2fa8026697d214222d857e178b4f5d1cf9f7d77f4db
@@ -0,0 +1 @@
1
+ tmp/
@@ -0,0 +1,12 @@
1
+ ARG RUBY_VERSION=2.7
2
+ FROM ruby:${RUBY_VERSION}
3
+
4
+ ENV GEM_HOME="/usr/local/bundle"
5
+ ENV PATH $GEM_HOME/bin:$GEM_HOME/gems/bin:$PATH
6
+ ENV QUIET=true
7
+ ENV CI=true
8
+
9
+ WORKDIR /code/enterprise-search-ruby
10
+
11
+ COPY . .
12
+ RUN bundle install
@@ -0,0 +1,50 @@
1
+ # CI certificates
2
+
3
+ This directory contains certificates that can be used to test against Elasticsearch in CI
4
+
5
+ ## Generating new certificates using the Certificate Authority cert and key
6
+
7
+ The `ca.crt` and `ca.key` can be used to generate any other certificates that may be needed
8
+ for CI. Perhaps the easiest way to do so is using
9
+ [`elasticsearch-certutil`](https://www.elastic.co/guide/en/elasticsearch/reference/current/certutil.html)
10
+
11
+ Using the elasticsearch docker container, run the following from the `.ci/certs` directory
12
+
13
+ ```sh
14
+ docker run \
15
+ -v "$PWD:/var/tmp" \
16
+ --rm docker.elastic.co/elasticsearch/elasticsearch:7.6.1 \
17
+ ./bin/elasticsearch-certutil cert \
18
+ --ca-cert /var/tmp/ca.crt --ca-key /var/tmp/ca.key --pem \
19
+ --out /var/tmp/bundle.zip
20
+ ```
21
+
22
+ This will output a `bundle.zip` file containing a directory named `instance` containing
23
+ `instance.crt` and `instance.key` in PEM format.
24
+
25
+ The CN Subject name can be changed using
26
+
27
+ ```sh
28
+ docker run \
29
+ -v "$PWD:/var/tmp" \
30
+ --rm docker.elastic.co/elasticsearch/elasticsearch:7.6.1 \
31
+ ./bin/elasticsearch-certutil cert \
32
+ --ca-cert /var/tmp/ca.crt --ca-key /var/tmp/ca.key --pem \
33
+ --out /var/tmp/bundle.zip \
34
+ --name foo
35
+ ```
36
+
37
+ The directory in `bundle.zip` will now be named `foo` and contain
38
+ `foo.crt` and `foo.key` in PEM format.
39
+
40
+ Additional DNS and IP SAN entries can be added with `--dns` and `--ip`, respectively.
41
+
42
+ ```sh
43
+ docker run \
44
+ -v "$PWD:/var/tmp" \
45
+ --rm docker.elastic.co/elasticsearch/elasticsearch:7.6.1 \
46
+ ./bin/elasticsearch-certutil cert \
47
+ --ca-cert /var/tmp/ca.crt --ca-key /var/tmp/ca.key --pem \
48
+ --out /var/tmp/bundle.zip \
49
+ --dns instance --dns localhost --dns es1 --ip 127.0.0.1 --ip ::1
50
+ ```
@@ -0,0 +1,20 @@
1
+ -----BEGIN CERTIFICATE-----
2
+ MIIDSjCCAjKgAwIBAgIVAJQLm8V2LcaCTHUcoIfO+KL63nG3MA0GCSqGSIb3DQEB
3
+ CwUAMDQxMjAwBgNVBAMTKUVsYXN0aWMgQ2VydGlmaWNhdGUgVG9vbCBBdXRvZ2Vu
4
+ ZXJhdGVkIENBMB4XDTIwMDIyNjA1NTA1N1oXDTIzMDIyNTA1NTA1N1owNDEyMDAG
5
+ A1UEAxMpRWxhc3RpYyBDZXJ0aWZpY2F0ZSBUb29sIEF1dG9nZW5lcmF0ZWQgQ0Ew
6
+ ggEiMA0GCSqGSIb3DQEBAQUAA4IBDwAwggEKAoIBAQDYyajkPvGtUOE5M1OowQfB
7
+ kWVrWjo1+LIxzgCeRHp0YztLtdVJ0sk2xoSrt2uZpxcPepdyOseLTjFJex1D2yCR
8
+ AEniIqcFif4G72nDih2LlbhpUe/+/MTryj8ZTkFTzI+eMmbQi5FFMaH+kwufmdt/
9
+ 5/w8YazO18SxxJUlzMqzfNUrhM8vvvVdxgboU7PWhk28wZHCMHQovomHmzclhRpF
10
+ N0FMktA98vHHeRjH19P7rNhifSd7hZzoH3H148HVAKoPgqnZ6vW2O2YfAWOP6ulq
11
+ cyszr57p8fS9B2wSdlWW7nVHU1JuKcYD67CxbBS23BeGFgCj4tiNrmxO8S5Yf85v
12
+ AgMBAAGjUzBRMB0GA1UdDgQWBBSWAlip9eoPmnG4p4OFZeOUBlAbNDAfBgNVHSME
13
+ GDAWgBSWAlip9eoPmnG4p4OFZeOUBlAbNDAPBgNVHRMBAf8EBTADAQH/MA0GCSqG
14
+ SIb3DQEBCwUAA4IBAQA19qqrMTWl7YyId+LR/QIHDrP4jfxmrEELrAL58q5Epc1k
15
+ XxZLzOBSXoBfBrPdv+3XklWqXrZjKWfdkux0Xmjnl4qul+srrZDLJVZG3I7IrITh
16
+ AmQUmL9MuPiMnAcxoGZp1xpijtW8Qmd2qnambbljWfkuVaa4hcVRfrAX6TciIQ21
17
+ bS5aeLGrPqR14h30YzDp0RMmTujEa1o6ExN0+RSTkE9m89Q6WdM69az8JW7YkWqm
18
+ I+UCG3TcLd3TXmN1zNQkq4y2ObDK4Sxy/2p6yFPI1Fds5w/zLfBOvvPQY61vEqs8
19
+ SCCcQIe7f6NDpIRIBlty1C9IaEHj7edyHjF6rtYb
20
+ -----END CERTIFICATE-----
@@ -0,0 +1,27 @@
1
+ -----BEGIN RSA PRIVATE KEY-----
2
+ MIIEpgIBAAKCAQEA2Mmo5D7xrVDhOTNTqMEHwZFla1o6NfiyMc4AnkR6dGM7S7XV
3
+ SdLJNsaEq7drmacXD3qXcjrHi04xSXsdQ9sgkQBJ4iKnBYn+Bu9pw4odi5W4aVHv
4
+ /vzE68o/GU5BU8yPnjJm0IuRRTGh/pMLn5nbf+f8PGGsztfEscSVJczKs3zVK4TP
5
+ L771XcYG6FOz1oZNvMGRwjB0KL6Jh5s3JYUaRTdBTJLQPfLxx3kYx9fT+6zYYn0n
6
+ e4Wc6B9x9ePB1QCqD4Kp2er1tjtmHwFjj+rpanMrM6+e6fH0vQdsEnZVlu51R1NS
7
+ binGA+uwsWwUttwXhhYAo+LYja5sTvEuWH/ObwIDAQABAoIBAQC8QDGnMnmPdWJ+
8
+ 13FYY3cmwel+FXXjFDk5QpgK15A2rUz6a8XxO1d7d1wR+U84uH4v9Na6XQyWjaoD
9
+ EyPQnuJiyAtgkZLUHoY244PGR5NsePEQlBSCKmGeF5w/j1LvP/2e9EmP4wKdQYJY
10
+ nLxFNcgEBCFnFbKIU5n8fKa/klybCrwlBokenyBro02tqH4LL7h1YMRRrl97fv1V
11
+ e/y/0WcMN+KnMglfz6haimBRV2yamCCHHmBImC+wzOgT/quqlxPfI+a3ScHxuA65
12
+ 3QyCavaqlPh+T3lXnN/Na4UWqFtzMmwgJX2x1zM5qiln46/JoDiXtagvV43L3rNs
13
+ LhPRFeIRAoGBAPhEB7nNpEDNjIRUL6WpebWS9brKAVY7gYn7YQrKGhhCyftyaiBZ
14
+ zYgxPaJdqYXf+DmkWlANGoYiwEs40QwkR/FZrvO4+Xh3n3dgtl59ZmieuoQvDsG+
15
+ RYIj+TfBaqhewhZNMMl7dxz7DeyQhyRCdsvl3VqJM0RuOsIrzrhCIEItAoGBAN+K
16
+ lgWI7swDpOEaLmu+IWMkGImh1LswXoZqIgi/ywZ7htZjPzidOIeUsMi+lrYsKojG
17
+ uU3sBxASsf9kYXDnuUuUbGT5M/N2ipXERt7klUAA/f5sg1IKlTrabaN/HGs/uNtf
18
+ Efa8v/h2VyTurdPCJ17TNpbOMDwX1qGM62tyt2CLAoGBAIHCnP8iWq18QeuQTO8b
19
+ a3/Z9hHRL22w4H4MI6aOB6GSlxuTq6CJD4IVqo9IwSg17fnCy2l3z9s4IqWuZqUf
20
+ +XJOW8ELd2jdrT2qEOfGR1Z7UCVyqxXcq1vgDYx0zZh/HpalddB5dcJx/c8do2Ty
21
+ UEE2PcHqYB9uNcvzNbLc7RtpAoGBALbuU0yePUTI6qGnajuTcQEPpeDjhRHWSFRZ
22
+ ABcG1N8uMS66Mx9iUcNp462zgeP8iqY5caUZtMHreqxT+gWKK7F0+as7386pwElF
23
+ QPXgO18QMMqHBIQb0vlBjJ1SRPBjSiSDTVEML1DljvTTOX7kEJHh6HdKrmBO5b54
24
+ cqMQUo53AoGBAPVWRPUXCqlBz914xKna0ZUh2aesRBg5BvOoq9ey9c52EIU5PXL5
25
+ 0Isk8sWSsvhl3tjDPBH5WuL5piKgnCTqkVbEHmWu9s1T57Mw6NuxlPMLBWvyv4c6
26
+ tB9brOxv0ui3qGMuBsBoDKbkNnwXyOXLyFg7O+H4l016A3mLQzJM+NGV
27
+ -----END RSA PRIVATE KEY-----
@@ -0,0 +1,21 @@
1
+ -----BEGIN CERTIFICATE-----
2
+ MIIDYjCCAkqgAwIBAgIVAIZQH0fe5U+bGQ6m1JUBO/AQkQ/9MA0GCSqGSIb3DQEB
3
+ CwUAMDQxMjAwBgNVBAMTKUVsYXN0aWMgQ2VydGlmaWNhdGUgVG9vbCBBdXRvZ2Vu
4
+ ZXJhdGVkIENBMB4XDTIwMDMyNzE5MTcxMVoXDTIzMDMyNzE5MTcxMVowEzERMA8G
5
+ A1UEAxMIaW5zdGFuY2UwggEiMA0GCSqGSIb3DQEBAQUAA4IBDwAwggEKAoIBAQDB
6
+ fco1t1+sE1gTwTVGcXKZqJTP2GjMHM0cfJE5KKfwC5B+pHADRT6FZxvepgKjEBDt
7
+ CK+2Rmotyeb15XXMSKguNhyT+2PuKvT5r05L7P91XRYXrwxG2swJPtct7A87xdFa
8
+ Ek+YRpqGGmTaux2jOELMiAmqEzoj6w/xFq+LF4SolTW4wOL2eLFkEFHBX2oCwU5T
9
+ Q+B+7E9zL45nFWlkeRGJ+ZQTnRNZ/1r4N9A9Gtj4x/H1/y4inWndikdxAb5QiEYJ
10
+ T+vbQWzHYWjz13ttHJsz+6T8rvA1jK+buHgVh4K8lV13X9k54soBqHB8va7/KIJP
11
+ g8gvd6vusEI7Bmfl1as7AgMBAAGjgYswgYgwHQYDVR0OBBYEFKnnpvuVYwtFSUis
12
+ WwN9OHLyExzJMB8GA1UdIwQYMBaAFJYCWKn16g+acbing4Vl45QGUBs0MDsGA1Ud
13
+ EQQ0MDKCCWxvY2FsaG9zdIIIaW5zdGFuY2WHBH8AAAGHEAAAAAAAAAAAAAAAAAAA
14
+ AAGCA2VzMTAJBgNVHRMEAjAAMA0GCSqGSIb3DQEBCwUAA4IBAQAPNsIoD4GBrTgR
15
+ jfvBuHS6eU16P95m16O8Mdpr4SMQgWLQUhs8aoVgfwpg2TkbCWxOe6khJOyNm7bf
16
+ fW4aFQ/OHcQV4Czz3c7eOHTWSyMlCOv+nRXd4giJZ5TOHw1zKGmKXOIvhvE6RfdF
17
+ uBBfrusk164H4iykm0Bbr/wo4d6wuebp3ZYLPw5zV0D08rsaR+3VJ9VxWuFpdm/r
18
+ 2onYOohyuX9DRjAczasC+CRRQN4eHJlRfSQB8WfTKw3EloRJJDAg6SJyGiAJ++BF
19
+ hnqfNcEyKes2AWagFF9aTbEJMrzMhH+YB5F+S/PWvMUlFzcoocVKqc4pIrjKUNWO
20
+ 6nbTxeAB
21
+ -----END CERTIFICATE-----
@@ -0,0 +1,27 @@
1
+ -----BEGIN RSA PRIVATE KEY-----
2
+ MIIEowIBAAKCAQEAwX3KNbdfrBNYE8E1RnFymaiUz9hozBzNHHyROSin8AuQfqRw
3
+ A0U+hWcb3qYCoxAQ7QivtkZqLcnm9eV1zEioLjYck/tj7ir0+a9OS+z/dV0WF68M
4
+ RtrMCT7XLewPO8XRWhJPmEaahhpk2rsdozhCzIgJqhM6I+sP8RavixeEqJU1uMDi
5
+ 9nixZBBRwV9qAsFOU0PgfuxPcy+OZxVpZHkRifmUE50TWf9a+DfQPRrY+Mfx9f8u
6
+ Ip1p3YpHcQG+UIhGCU/r20Fsx2Fo89d7bRybM/uk/K7wNYyvm7h4FYeCvJVdd1/Z
7
+ OeLKAahwfL2u/yiCT4PIL3er7rBCOwZn5dWrOwIDAQABAoIBAFcm4ICnculf4Sks
8
+ umFbUiISA81GjZV6V4zAMu1K+bGuk8vnJyjh9JJD6hK0NbXa07TgV7zDJKoxKd2S
9
+ GCgGhfIin2asMcuh/6vDIYIjYsErR3stdlsnzAVSD7v4ergSlwR6AO32xz0mAE1h
10
+ QK029yeHEstPU72/7/NIo5MD6dXAbut1MzgijZD8RQo1z21D6qmLcPTVTfkn7a3W
11
+ MY3y7XUIkA1TOyIRsH3k6F6NBWkvtXbwOUeLCJ14EvS8T9BqhIhPDZv8mQTRLDOD
12
+ tQRyC4Cnw+UhYmnMFJhj6N2jpTBv/AdoKcRC56uBJyPW+dxj6i4e7n3pQuxqRvpI
13
+ LLJJsskCgYEA4QQxzuJizLKV75rE+Qxg0Ej0Gid1aj3H5eeTZOUhm9KC8KDfPdpk
14
+ msKaNzJq/VDcqHPluGS1jYZVgZlal1nk5xKBcbQ4n297VPVd+sLtlf0bj4atlDUO
15
+ +iOVo0H7k5yWvj+TzVRlc5zjDLcnQh8i+22o3+65hIrb2zpzg/cCZJ8CgYEA3CJX
16
+ bjmWPQ0uZVIa8Wz8cJFtKT9uVl7Z3/f6HjN9I0b/9MmVlNxQVAilVwhDkzR/UawG
17
+ QeRFBJ6XWRwX0aoMq+O9VSNu/R2rtEMpIYt3LwbI3yw6GRoCdB5qeL820O+KX5Fl
18
+ /z+ZNgrHgA1yKPVf+8ke2ZtLEqPHMN+BMuq8t+UCgYEAy0MfvzQPbbuw55WWcyb0
19
+ WZJdNzcHwKX4ajzrj4vP9VOPRtD7eINMt+QsrMnVjei6u0yeahhHTIXZvc2K4Qeq
20
+ V/YGinDzaUqqTU+synXFauUOPXO6XxQi6GC2rphPKsOcBFWoLSYc0vgYvgbA5uD7
21
+ l8Yyc77RROKuwfWmHcJHHh8CgYBurGFSjGdJWHgr/oSHPqkIG0VLiJV7nQJjBPRd
22
+ /Lr8YnTK6BJpHf7Q0Ov3frMirjEYqakXtaExel5TMbmT8q+eN8h3pnHlleY+oclr
23
+ EQghv4J8GWs4NYhoQuZ6wH/ZuaTS+XHTS3FG51J3wcrUZtET8ICvHNE4lNjPbH8z
24
+ TysENQKBgHER1RtDFdz+O7mlWibrHk8JDgcVdZV/pBF+9cb7r/orkH9RLAHDlsAO
25
+ tuSVaQmm5eqgaAxMamBXSyw1lir07byemyuEDg0mJ1rNUGsAY8P+LWr579gvKMme
26
+ 5gvrJr99JkBTV3z+TiL7dZa52eW00Ijqg2qcbHGpq3kXWWkbd8Tn
27
+ -----END RSA PRIVATE KEY-----
@@ -0,0 +1,19 @@
1
+ -----BEGIN CERTIFICATE-----
2
+ MIIDIzCCAgugAwIBAgIVAMTO6uVx9dLox2t0lY4IcBKZXb5WMA0GCSqGSIb3DQEB
3
+ CwUAMDQxMjAwBgNVBAMTKUVsYXN0aWMgQ2VydGlmaWNhdGUgVG9vbCBBdXRvZ2Vu
4
+ ZXJhdGVkIENBMB4XDTIwMDIyNjA1NTA1OVoXDTIzMDIyNTA1NTA1OVowEzERMA8G
5
+ A1UEAxMIaW5zdGFuY2UwggEiMA0GCSqGSIb3DQEBAQUAA4IBDwAwggEKAoIBAQDK
6
+ YLTOikVENiN/qYupOsoXd7VYYnryyfCC/dK4FC2aozkbqjFzBdvPGAasoc4yEiH5
7
+ CGeXMgJuOjk1maqetmdIsw00j4oHJviYsnGXzxxS5swhD7spcW4Uk4V4tAUzrbfT
8
+ vW/2WW/yYCLe5phVb2chz0jL+WYb4bBmdfs/t6RtP9RqsplYAmVp3gZ6lt2YNtvE
9
+ k9gz0TVk3DuO1TquIClfRYUjuywS6xDSvxJ8Jl91EfDWM8QU+9F+YAtiv74xl2U3
10
+ P0wwMqNvMxf9/3ak3lTQGsgO4L6cwbKpVLMMzxSVunZz/sgl19xy3qHHz1Qr2MjJ
11
+ /2c2J7vahUL4NPRkjJClAgMBAAGjTTBLMB0GA1UdDgQWBBS2Wn8E2VZv4oenY+pR
12
+ O8G3zfQXhzAfBgNVHSMEGDAWgBSWAlip9eoPmnG4p4OFZeOUBlAbNDAJBgNVHRME
13
+ AjAAMA0GCSqGSIb3DQEBCwUAA4IBAQAvwPvCiJJ6v9jYcyvYY8I3gP0oCwrylpRL
14
+ n91UlgRSHUmuAObyOoVN5518gSV/bTU2SDrstcLkLFxHvnfpoGJoxsQEHuGxwDRI
15
+ nhYNd62EKLerehNM/F9ILKmvTh8f6QPCzjUuExTXv+63l2Sr6dBS7FHsGs6UKUYO
16
+ llM/y9wMZ1LCuZuBg9RhtgpFXRSgDM9Z7Begu0d/BPX9od/qAeZg9Arz4rwUiCN4
17
+ IJOMEBEPi5q1tgeS0Fb1Grpqd0Uz5tZKtEHNKzLG+zSMmkneL62Nk2HsmEFZKwzg
18
+ u2pU42UaUE596G6o78s1aLn9ICcElPHTjiuZNSiyuu9IzvFDjGQw
19
+ -----END CERTIFICATE-----
@@ -0,0 +1,27 @@
1
+ -----BEGIN RSA PRIVATE KEY-----
2
+ MIIEogIBAAKCAQEAymC0zopFRDYjf6mLqTrKF3e1WGJ68snwgv3SuBQtmqM5G6ox
3
+ cwXbzxgGrKHOMhIh+QhnlzICbjo5NZmqnrZnSLMNNI+KByb4mLJxl88cUubMIQ+7
4
+ KXFuFJOFeLQFM623071v9llv8mAi3uaYVW9nIc9Iy/lmG+GwZnX7P7ekbT/UarKZ
5
+ WAJlad4GepbdmDbbxJPYM9E1ZNw7jtU6riApX0WFI7ssEusQ0r8SfCZfdRHw1jPE
6
+ FPvRfmALYr++MZdlNz9MMDKjbzMX/f92pN5U0BrIDuC+nMGyqVSzDM8Ulbp2c/7I
7
+ Jdfcct6hx89UK9jIyf9nNie72oVC+DT0ZIyQpQIDAQABAoIBADAh7f7NjgnaInlD
8
+ ds8KB3SraPsbeQhzlPtiqRJU4j/MIFH/GYG03AGWQkget67a9y+GmzSvlTpoKKEh
9
+ 6h2TXl9BDpv4o6ht0WRn1HJ5tM/Wyqf2WNpTew3zxCPgFPikkXsPrChYPzLTQJfp
10
+ GkP/mfTFmxfAOlPZSp4j41zVLYs53eDkAegFPVfKSr1XNNJ3QODLPcIBfxBYsiC9
11
+ oU+jRW8xYuj31cEl5k5UqrChJ1rm3mt6cguqXKbISuoSvi13gXI6DccqhuLAU+Kr
12
+ ib2XYrRP+pWocZo/pM9WUVoNGtFxfY88sAQtvG6gDKo2AURtFyq84Ow0h9mdixV/
13
+ gRIDPcECgYEA5nEqE3OKuG9WuUFGXvjtn4C0F6JjflYWh7AbX51S4F6LKrW6/XHL
14
+ Rg4BtF+XReT7OQ6llsV8kZeUxsUckkgDLzSaA8lysNDV5KkhAWHfRqH//QKFbqZi
15
+ JL9t3x63Qt81US8s2hQk3khPYTRM8ZB3xHiXvZYSGC/0x/DxfEO3QJECgYEA4NK5
16
+ sxtrat8sFz6SK9nWEKimPjDVzxJ0hxdX4tRq/JdOO5RncawVqt6TNP9gTuxfBvhW
17
+ MhJYEsQj8iUoL1dxo9d1eP8HEANNV0iX5OBvJNmgBp+2OyRSyr+PA55+wAxYuAE7
18
+ QKaitOjW57fpArNRt2hQyiSzTuqUFRWTWJHCWNUCgYAEurPTXF6vdFGCUc2g61jt
19
+ GhYYGhQSpq+lrz6Qksj9o9MVWE9zHh++21C7o+6V16I0RJGva3QoBMVf4vG4KtQt
20
+ 5tV2WG8LI+4P2Ey+G4UajP6U8bVNVQrUmD0oBBhcvfn5JY+1Fg6/pRpD82/U0VMz
21
+ 7AmpMWhDqNBMPiymkTk0kQKBgCuWb05cSI0ly4SOKwS5bRk5uVFhYnKNH255hh6C
22
+ FGP4acB/WzbcqC7CjEPAJ0nl5d6SExQOHmk1AcsWjR3wlCWxxiK5PwNJwJrlhh1n
23
+ reS1FKN0H36D4lFQpkeLWQOe4Sx7gKNeKzlr0w6Fx3Uwku0+Gju2tdTdAey8jB6l
24
+ 08opAoGAEe1AuR/OFp2xw6V8TH9UHkkpGxy+OrXI6PX6tgk29PgB+uiMu4RwbjVz
25
+ 1di1KKq2XecAilVbnyqY+edADxYGbSnci9x5wQRIebfMi3VXKtV8NQBv2as6qwtW
26
+ JDcQUWotOHjpdvmfJWWkcBhbAKrgX8ukww00ZI/lC3/rmkGnBBg=
27
+ -----END RSA PRIVATE KEY-----
@@ -0,0 +1,67 @@
1
+ #!/usr/bin/env bash
2
+ #
3
+ # Shared cleanup routines between different steps
4
+ #
5
+ # Please source .ci/functions/imports.sh as a whole not just this file
6
+ #
7
+ # Version 1.0.0
8
+ # - Initial version after refactor
9
+
10
+ function cleanup_volume {
11
+ if [[ "$(docker volume ls -q -f name=$1)" ]]; then
12
+ echo -e "\033[34;1mINFO:\033[0m Removing volume $1\033[0m"
13
+ (docker volume rm "$1") || true
14
+ fi
15
+ }
16
+ function container_running {
17
+ if [[ "$(docker ps -q -f name=$1)" ]]; then
18
+ return 0;
19
+ else return 1;
20
+ fi
21
+ }
22
+ function cleanup_node {
23
+ if container_running "$1"; then
24
+ echo -e "\033[34;1mINFO:\033[0m Removing container $1\033[0m"
25
+ (docker container rm --force --volumes "$1") || true
26
+ fi
27
+ if [[ -n "$1" ]]; then
28
+ echo -e "\033[34;1mINFO:\033[0m Removing volume $1-${suffix}-data\033[0m"
29
+ cleanup_volume "$1-${suffix}-data"
30
+ fi
31
+ }
32
+ function cleanup_network {
33
+ if [[ "$(docker network ls -q -f name=$1)" ]]; then
34
+ echo -e "\033[34;1mINFO:\033[0m Removing network $1\033[0m"
35
+ (docker network rm "$1") || true
36
+ fi
37
+ }
38
+
39
+ function cleanup_trap {
40
+ status=$?
41
+ set +x
42
+ if [[ "$DETACH" != "true" ]]; then
43
+ echo -e "\033[34;1mINFO:\033[0m clean the network if not detached (start and exit)\033[0m"
44
+ cleanup_all_in_network "$1"
45
+ fi
46
+ # status is 0 or SIGINT
47
+ if [[ "$status" == "0" || "$status" == "130" ]]; then
48
+ echo -e "\n\033[32;1mSUCCESS run-tests\033[0m"
49
+ exit 0
50
+ else
51
+ echo -e "\n\033[31;1mFAILURE during run-tests\033[0m"
52
+ exit ${status}
53
+ fi
54
+ };
55
+ function cleanup_all_in_network {
56
+
57
+ if [[ -z "$(docker network ls -q -f name="^$1\$")" ]]; then
58
+ echo -e "\033[34;1mINFO:\033[0m $1 is already deleted\033[0m"
59
+ return 0
60
+ fi
61
+ containers=$(docker network inspect -f '{{ range $key, $value := .Containers }}{{ printf "%s\n" .Name}}{{ end }}' $1)
62
+ while read -r container; do
63
+ cleanup_node "$container"
64
+ done <<< "$containers"
65
+ cleanup_network $1
66
+ echo -e "\033[32;1mSUCCESS:\033[0m Cleaned up and exiting\033[0m"
67
+ };
@@ -0,0 +1,60 @@
1
+ #!/usr/bin/env bash
2
+ #
3
+ # Sets up all the common variables and imports relevant functions
4
+ #
5
+ # Version 1.0.1
6
+ # - Initial version after refactor
7
+ # - Validate STACK_VERSION asap
8
+
9
+ function require_stack_version() {
10
+ if [[ -z $STACK_VERSION ]]; then
11
+ echo -e "\033[31;1mERROR:\033[0m Required environment variable [STACK_VERSION] not set\033[0m"
12
+ exit 1
13
+ fi
14
+ }
15
+
16
+ require_stack_version
17
+
18
+ if [[ -z $es_node_name ]]; then
19
+ # only set these once
20
+ set -euo pipefail
21
+ export TEST_SUITE=${TEST_SUITE-oss}
22
+ export RUNSCRIPTS=${RUNSCRIPTS-}
23
+ export DETACH=${DETACH-false}
24
+ export CLEANUP=${CLEANUP-false}
25
+
26
+ export es_node_name=instance
27
+ export elastic_password=changeme
28
+ export elasticsearch_image=elasticsearch
29
+ export elasticsearch_url=https://elastic:${elastic_password}@${es_node_name}:9200
30
+ if [[ $TEST_SUITE != "xpack" ]]; then
31
+ export elasticsearch_image=elasticsearch-${TEST_SUITE}
32
+ export elasticsearch_url=http://${es_node_name}:9200
33
+ fi
34
+ export external_elasticsearch_url=${elasticsearch_url/$es_node_name/localhost}
35
+ export elasticsearch_container="${elasticsearch_image}:${STACK_VERSION}"
36
+
37
+ export suffix=rest-test
38
+ export moniker=$(echo "$elasticsearch_container" | tr -C "[:alnum:]" '-')
39
+ export network_name=${moniker}${suffix}
40
+
41
+ export ssl_cert="${script_path}/certs/testnode.crt"
42
+ export ssl_key="${script_path}/certs/testnode.key"
43
+ export ssl_ca="${script_path}/certs/ca.crt"
44
+
45
+ fi
46
+
47
+ export script_path=$(dirname $(realpath -s $0))
48
+ source $script_path/functions/cleanup.sh
49
+ source $script_path/functions/wait-for-container.sh
50
+ trap "cleanup_trap ${network_name}" EXIT
51
+
52
+
53
+ if [[ "$CLEANUP" == "true" ]]; then
54
+ cleanup_all_in_network $network_name
55
+ exit 0
56
+ fi
57
+
58
+ echo -e "\033[34;1mINFO:\033[0m Creating network $network_name if it does not exist already \033[0m"
59
+ docker network inspect "$network_name" > /dev/null 2>&1 || docker network create "$network_name"
60
+
@@ -0,0 +1,36 @@
1
+ #!/usr/bin/env bash
2
+ #
3
+ # Exposes a routine scripts can call to wait for a container if that container set up a health command
4
+ #
5
+ # Please source .ci/functions/imports.sh as a whole not just this file
6
+ #
7
+ # Version 1.0.1
8
+ # - Initial version after refactor
9
+ # - Make sure wait_for_contiainer is silent
10
+
11
+ function wait_for_container {
12
+ set +x
13
+ until ! container_running "$1" || (container_running "$1" && [[ "$(docker inspect -f "{{.State.Health.Status}}" ${1})" != "starting" ]]); do
14
+ echo ""
15
+ docker inspect -f "{{range .State.Health.Log}}{{.Output}}{{end}}" ${1}
16
+ echo -e "\033[34;1mINFO:\033[0m waiting for node $1 to be up\033[0m"
17
+ sleep 20;
18
+ done;
19
+
20
+ # Always show logs if the container is running, this is very useful both on CI as well as while developing
21
+ if container_running $1; then
22
+ docker logs $1
23
+ fi
24
+
25
+ if ! container_running $1 || [[ "$(docker inspect -f "{{.State.Health.Status}}" ${1})" != "healthy" ]]; then
26
+ cleanup_all_in_network $2
27
+ echo
28
+ echo -e "\033[31;1mERROR:\033[0m Failed to start $1 in detached mode beyond health checks\033[0m"
29
+ echo -e "\033[31;1mERROR:\033[0m dumped the docker log before shutting the node down\033[0m"
30
+ return 1
31
+ else
32
+ echo
33
+ echo -e "\033[32;1mSUCCESS:\033[0m Detached and healthy: ${1} on docker network: ${network_name}\033[0m"
34
+ return 0
35
+ fi
36
+ }
@@ -0,0 +1,69 @@
1
+ ---
2
+
3
+ ##### GLOBAL METADATA
4
+
5
+ - meta:
6
+ cluster: clients-ci
7
+
8
+ ##### JOB DEFAULTS
9
+
10
+ - job:
11
+ project-type: matrix
12
+ logrotate:
13
+ daysToKeep: 30
14
+ numToKeep: 100
15
+ properties:
16
+ - github:
17
+ url: https://github.com/elastic/enterprise-search-ruby/
18
+ - inject:
19
+ properties-content: HOME=$JENKINS_HOME
20
+ concurrent: true
21
+ node: flyweight
22
+ scm:
23
+ - git:
24
+ name: origin
25
+ credentials-id: f6c7695a-671e-4f4f-a331-acdce44ff9ba
26
+ reference-repo: /var/lib/jenkins/.git-references/enterprise-search-ruby.git
27
+ branches:
28
+ - ${branch_specifier}
29
+ url: git@github.com:elastic/enterprise-search-ruby.git
30
+ basedir: ''
31
+ wipe-workspace: 'True'
32
+ triggers:
33
+ - github
34
+ - timed: 'H 5,17 * * *'
35
+ axes:
36
+ - axis:
37
+ type: slave
38
+ name: label
39
+ values:
40
+ - linux
41
+ - axis:
42
+ type: yaml
43
+ filename: .ci/test-matrix.yml
44
+ name: STACK_VERSION
45
+ - axis:
46
+ type: yaml
47
+ filename: .ci/test-matrix.yml
48
+ name: RUBY_VERSION
49
+ yaml-strategy:
50
+ exclude-key: exclude
51
+ filename: .ci/test-matrix.yml
52
+ wrappers:
53
+ - ansicolor
54
+ - timeout:
55
+ type: absolute
56
+ timeout: 120
57
+ fail: true
58
+ - timestamps
59
+ - workspace-cleanup
60
+ builders:
61
+ - shell: |-
62
+ #!/usr/local/bin/runbld
63
+ .ci/run-tests
64
+ publishers:
65
+ - email:
66
+ recipients: build-lang-clients@elastic.co
67
+ - junit:
68
+ results: "*-junit.xml"
69
+ allow-empty-results: true