168 lines
5.7 KiB
Groovy
168 lines
5.7 KiB
Groovy
import org.elasticsearch.gradle.precommit.PrecommitTasks
|
|
import org.elasticsearch.gradle.test.RunTask
|
|
|
|
description = 'Integration tests for SQL'
|
|
apply plugin: 'elasticsearch.build'
|
|
|
|
dependencies {
|
|
compile "org.elasticsearch.test:framework:${versions.elasticsearch}"
|
|
|
|
// JDBC testing dependencies
|
|
compile(project(':x-pack-elasticsearch:sql:jdbc')) {
|
|
if (false == isEclipse && false == isIdea) {
|
|
/* Skip the transitive dependencies of the server when outside
|
|
* of an IDE because outside of an IDE we use the jdbc jar
|
|
* which includes all the transitive dependencies *already*.
|
|
* If we didn't skip these dependencies the jar hell checks
|
|
* would fail. And we need the transitive dependencies to
|
|
* run in embedded mode but only do that inside of an IDE. */
|
|
transitive = false
|
|
}
|
|
}
|
|
compile "net.sourceforge.csvjdbc:csvjdbc:1.0.31"
|
|
runtime "com.h2database:h2:1.4.194"
|
|
|
|
// There are *no* CLI testing dependencies because we
|
|
// communicate fork a new CLI process when we need it.
|
|
|
|
// Used to support embedded testing mode
|
|
compile(project(':x-pack-elasticsearch:sql:server')) {
|
|
transitive = false
|
|
}
|
|
compile(project(':x-pack-elasticsearch:sql:cli-proto')) {
|
|
transitive = false
|
|
}
|
|
compile "org.elasticsearch.client:transport:${version}"
|
|
}
|
|
|
|
/* disable unit tests because these are all integration tests used
|
|
* other qa projects. */
|
|
test.enabled = false
|
|
|
|
dependencyLicenses.enabled = false
|
|
|
|
// Allow for com.sun.net.httpserver.* usage for embedded mode
|
|
eclipse {
|
|
classpath.file {
|
|
whenMerged { cp ->
|
|
def con = entries.find { e ->
|
|
e.kind == "con" && e.toString().contains("org.eclipse.jdt.launching.JRE_CONTAINER")
|
|
}
|
|
con.accessRules.add(new org.gradle.plugins.ide.eclipse.model.AccessRule(
|
|
"accessible", "com/sun/net/httpserver/*"))
|
|
}
|
|
}
|
|
}
|
|
forbiddenApisMain {
|
|
bundledSignatures -= 'jdk-non-portable'
|
|
bundledSignatures += 'jdk-internal'
|
|
}
|
|
|
|
// the main files are actually test files, so use the appropriate forbidden api sigs
|
|
forbiddenApisMain {
|
|
signaturesURLs = [PrecommitTasks.getResource('/forbidden/es-all-signatures.txt'),
|
|
PrecommitTasks.getResource('/forbidden/es-test-signatures.txt')]
|
|
}
|
|
|
|
thirdPartyAudit.excludes = [
|
|
// H2 dependencies that we don't actually use....
|
|
'javax.servlet.ServletConfig',
|
|
'javax.servlet.ServletContext',
|
|
'javax.servlet.ServletContextEvent',
|
|
'javax.servlet.ServletContextListener',
|
|
'javax.servlet.ServletOutputStream',
|
|
'javax.servlet.http.HttpServlet',
|
|
'javax.servlet.http.HttpServletRequest',
|
|
'javax.servlet.http.HttpServletResponse',
|
|
'org.apache.lucene.document.Field$Index',
|
|
'org.apache.lucene.queryParser.QueryParser',
|
|
'org.osgi.framework.BundleActivator',
|
|
'org.osgi.framework.BundleContext',
|
|
'org.osgi.service.jdbc.DataSourceFactory',
|
|
'org.slf4j.Logger',
|
|
'org.slf4j.LoggerFactory',
|
|
]
|
|
|
|
subprojects {
|
|
apply plugin: 'elasticsearch.standalone-rest-test'
|
|
apply plugin: 'elasticsearch.rest-test'
|
|
|
|
configurations {
|
|
cliFixture
|
|
}
|
|
|
|
dependencies {
|
|
/* Since we're a standalone rest test we actually get transitive
|
|
* dependencies but we don't really want them because they cause
|
|
* all kinds of trouble with the jar hell checks. So we suppress
|
|
* them explicitly for non-es projects. */
|
|
testCompile(project(':x-pack-elasticsearch:qa:sql')) {
|
|
transitive = false
|
|
}
|
|
testCompile "org.elasticsearch.test:framework:${versions.elasticsearch}"
|
|
|
|
// JDBC testing dependencies
|
|
testRuntime(project(':x-pack-elasticsearch:sql:jdbc')) {
|
|
if (false == isEclipse && false == isIdea) {
|
|
/* Skip the transitive dependencies of the server when outside
|
|
* of an IDE because outside of an IDE we use the jdbc jar
|
|
* which includes all the transitive dependencies *already*.
|
|
* If we didn't skip these dependencies the jar hell checks
|
|
* would fail. And we need the transitive dependencies to
|
|
* run in embedded mode but only do that inside of an IDE. */
|
|
transitive = false
|
|
}
|
|
}
|
|
testRuntime("net.sourceforge.csvjdbc:csvjdbc:1.0.31") {
|
|
transitive = false
|
|
}
|
|
testRuntime("com.h2database:h2:1.4.194") {
|
|
transitive = false
|
|
}
|
|
|
|
cliFixture project(':x-pack-elasticsearch:test:sql-cli-fixture')
|
|
|
|
// Used to support embedded testing mode
|
|
testRuntime(project(':x-pack-elasticsearch:sql:server')) {
|
|
transitive = false
|
|
}
|
|
testRuntime "org.elasticsearch.client:transport:${version}"
|
|
}
|
|
|
|
task cliFixture(type: org.elasticsearch.gradle.test.AntFixture) {
|
|
Project cli = project(':x-pack-elasticsearch:sql:cli')
|
|
dependsOn project.configurations.cliFixture
|
|
dependsOn cli.jar
|
|
executable = new File(project.javaHome, 'bin/java')
|
|
env 'CLASSPATH', "${ -> project.configurations.cliFixture.asPath }"
|
|
args 'org.elasticsearch.xpack.sql.cli.fixture.CliFixture',
|
|
baseDir, "${ -> cli.jar.outputs.files.singleFile}"
|
|
}
|
|
|
|
integTestCluster {
|
|
distribution = 'zip'
|
|
plugin project(':x-pack-elasticsearch:plugin').path
|
|
setting 'xpack.monitoring.enabled', 'false'
|
|
setting 'xpack.ml.enabled', 'false'
|
|
setting 'xpack.watcher.enabled', 'false'
|
|
setting 'script.max_compilations_rate', '1000/1m'
|
|
dependsOn cliFixture
|
|
}
|
|
|
|
integTestRunner {
|
|
systemProperty 'tests.cli.fixture', "${ -> cliFixture.addressAndPort }"
|
|
finalizedBy cliFixture.stopTask
|
|
}
|
|
|
|
task run(type: RunTask) {
|
|
distribution = 'zip'
|
|
plugin project(':x-pack-elasticsearch:plugin').path
|
|
setting 'xpack.monitoring.enabled', 'false'
|
|
setting 'xpack.ml.enabled', 'false'
|
|
setting 'xpack.watcher.enabled', 'false'
|
|
setting 'script.max_compilations_rate', '1000/1m'
|
|
dependsOn cliFixture
|
|
}
|
|
run.finalizedBy cliFixture.stopTask
|
|
}
|