119 lines
5.3 KiB
Groovy
119 lines
5.3 KiB
Groovy
import org.elasticsearch.gradle.test.RestIntegTestTask
|
|
import org.elasticsearch.gradle.info.BuildParams
|
|
|
|
/*
|
|
* Licensed to Elasticsearch under one or more contributor
|
|
* license agreements. See the NOTICE file distributed with
|
|
* this work for additional information regarding copyright
|
|
* ownership. Elasticsearch licenses this file to you under
|
|
* the Apache License, Version 2.0 (the "License"); you may
|
|
* not use this file except in compliance with the License.
|
|
* You may obtain a copy of the License at
|
|
*
|
|
* http://www.apache.org/licenses/LICENSE-2.0
|
|
*
|
|
* Unless required by applicable law or agreed to in writing,
|
|
* software distributed under the License is distributed on an
|
|
* "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
|
|
* KIND, either express or implied. See the License for the
|
|
* specific language governing permissions and limitations
|
|
* under the License.
|
|
*/
|
|
apply plugin: 'elasticsearch.testclusters'
|
|
apply plugin: 'elasticsearch.build'
|
|
apply plugin: 'elasticsearch.rest-test'
|
|
apply plugin: 'elasticsearch.publish'
|
|
apply plugin: 'elasticsearch.rest-resources'
|
|
|
|
group = 'org.elasticsearch.client'
|
|
archivesBaseName = 'elasticsearch-rest-high-level-client'
|
|
|
|
restResources {
|
|
//we need to copy the yaml spec so we can check naming (see RestHighlevelClientTests#testApiNamingConventions)
|
|
restApi {
|
|
includeCore '*'
|
|
}
|
|
}
|
|
|
|
dependencies {
|
|
api project(':server')
|
|
api project(':client:rest')
|
|
api project(':modules:mapper-extras')
|
|
api project(':modules:parent-join')
|
|
api project(':modules:aggs-matrix-stats')
|
|
api project(':modules:rank-eval')
|
|
api project(':modules:lang-mustache')
|
|
|
|
testImplementation project(':client:test')
|
|
testImplementation project(':test:framework')
|
|
testImplementation "com.carrotsearch.randomizedtesting:randomizedtesting-runner:${versions.randomizedrunner}"
|
|
testImplementation "junit:junit:${versions.junit}"
|
|
//this is needed to make RestHighLevelClientTests#testApiNamingConventions work from IDEs
|
|
testImplementation project(":rest-api-spec")
|
|
// Needed for serialization tests:
|
|
// (In order to serialize a server side class to a client side class or the other way around)
|
|
testImplementation(project(':x-pack:plugin:core')) {
|
|
exclude group: 'org.elasticsearch', module: 'elasticsearch-rest-high-level-client'
|
|
}
|
|
testImplementation(project(':x-pack:plugin:eql'))
|
|
}
|
|
|
|
tasks.named('forbiddenApisMain').configure {
|
|
// core does not depend on the httpclient for compile so we add the signatures here. We don't add them for test as they are already
|
|
// specified
|
|
addSignatureFiles 'http-signatures'
|
|
signaturesFiles += files('src/main/resources/forbidden/rest-high-level-signatures.txt')
|
|
}
|
|
|
|
File nodeCert = file("./testnode.crt")
|
|
File nodeTrustStore = file("./testnode.jks")
|
|
File pkiTrustCert = file("./src/test/resources/org/elasticsearch/client/security/delegate_pki/testRootCA.crt")
|
|
|
|
integTest {
|
|
systemProperty 'tests.rest.async', 'false'
|
|
systemProperty 'tests.rest.cluster.username', System.getProperty('tests.rest.cluster.username', 'test_user')
|
|
systemProperty 'tests.rest.cluster.password', System.getProperty('tests.rest.cluster.password', 'test-password')
|
|
}
|
|
|
|
RestIntegTestTask asyncIntegTest = tasks.create("asyncIntegTest", RestIntegTestTask) {
|
|
systemProperty 'tests.rest.async', 'true'
|
|
systemProperty 'tests.rest.cluster.username', System.getProperty('tests.rest.cluster.username', 'test_user')
|
|
systemProperty 'tests.rest.cluster.password', System.getProperty('tests.rest.cluster.password', 'test-password')
|
|
}
|
|
|
|
check.dependsOn(asyncIntegTest)
|
|
|
|
testClusters.all {
|
|
testDistribution = 'DEFAULT'
|
|
systemProperty 'es.scripting.update.ctx_in_params', 'false'
|
|
setting 'reindex.remote.whitelist', '[ "[::1]:*", "127.0.0.1:*" ]'
|
|
setting 'xpack.license.self_generated.type', 'trial'
|
|
setting 'xpack.security.enabled', 'true'
|
|
setting 'xpack.security.authc.token.enabled', 'true'
|
|
setting 'xpack.security.authc.api_key.enabled', 'true'
|
|
setting 'xpack.security.http.ssl.enabled', 'false'
|
|
setting 'xpack.security.transport.ssl.enabled', 'false'
|
|
setting 'xpack.eql.enabled', 'true'
|
|
// Truststore settings are not used since TLS is not enabled. Included for testing the get certificates API
|
|
setting 'xpack.security.http.ssl.certificate_authorities', 'testnode.crt'
|
|
setting 'xpack.security.transport.ssl.truststore.path', 'testnode.jks'
|
|
setting 'xpack.security.authc.realms.file.default_file.order', '0'
|
|
setting 'xpack.security.authc.realms.native.default_native.order', '1'
|
|
setting 'xpack.security.authc.realms.pki.pki1.order', '2'
|
|
setting 'xpack.security.authc.realms.pki.pki1.certificate_authorities', '[ "testRootCA.crt" ]'
|
|
setting 'xpack.security.authc.realms.pki.pki1.delegation.enabled', 'true'
|
|
|
|
setting 'indices.lifecycle.poll_interval', '1000ms'
|
|
setting 'indices.lifecycle.history_index_enabled', 'false'
|
|
keystore 'xpack.security.transport.ssl.truststore.secure_password', 'testnode'
|
|
extraConfigFile 'roles.yml', file('roles.yml')
|
|
user username: System.getProperty('tests.rest.cluster.username', 'test_user'),
|
|
password: System.getProperty('tests.rest.cluster.password', 'test-password'),
|
|
role: System.getProperty('tests.rest.cluster.role', 'admin')
|
|
user username: 'admin_user', password: 'admin-password'
|
|
|
|
extraConfigFile nodeCert.name, nodeCert
|
|
extraConfigFile nodeTrustStore.name, nodeTrustStore
|
|
extraConfigFile pkiTrustCert.name, pkiTrustCert
|
|
}
|