blob: 77fd3bef6d0d39d234bc87f94cdc388890247026 [file] [log] [blame]
/*
* Licensed to the Apache Software Foundation (ASF) under one
* or more contributor license agreements. See the NOTICE file
* distributed with this work for additional information
* regarding copyright ownership. The ASF 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.
*/
plugins { id 'org.apache.beam.module' }
applyGoNature()
description = "Apache Beam :: SDKs :: Go :: Test"
// Figure out why the golang plugin does not add a build dependency between projects.
// Without the line below, we get spurious errors about not being able to resolve
// "./github.com/apache/beam/sdks/go"
resolveBuildDependencies.dependsOn ":sdks:go:goBuild"
dependencies {
golang {
// TODO(herohde): use "./" prefix to prevent gogradle use base github path, for now.
// TODO(herohde): get the pkg subdirectory only, if possible. We spend mins pulling cmd/beamctl deps.
build name: './github.com/apache/beam/sdks/go', dir: project(':sdks:go').projectDir
test name: './github.com/apache/beam/sdks/go', dir: project(':sdks:go').projectDir
}
}
golang {
packagePath = 'github.com/apache/beam/sdks/go/test'
goBuild {
// Build the linux-amd64 worker. The native version is built in the parent to
// have a fixed name, which is not possible with multiple target platforms. The
// script would otherwise have to figure out which arch/platform binary to invoke.
targetPlatform = ['linux-amd64']
go 'build -o ./build/bin/linux-amd64/worker github.com/apache/beam/sdks/go/test/integration'
}
}
task flinkValidatesRunner {
dependsOn ":sdks:go:test:goBuild"
dependsOn ":runners:flink:1.8:job-server:shadowJar"
doLast {
def options = [
"--runner flink",
"--parallel 1", // prevent memory overuse
"--flink_job_server_jar ${project(":runners:flink:1.8:job-server").shadowJar.archivePath}",
]
exec {
executable "sh"
args "-c", "./run_integration_tests.sh ${options.join(' ')}"
}
}
}
task sparkValidatesRunner {
dependsOn ":sdks:go:test:goBuild"
dependsOn ":runners:spark:job-server:shadowJar"
doLast {
def options = [
"--runner spark",
"--parallel 1", // prevent memory overuse
"--spark_job_server_jar ${project(":runners:spark:job-server").shadowJar.archivePath}",
]
exec {
executable "sh"
args "-c", "./run_integration_tests.sh ${options.join(' ')}"
}
}
}