| /* |
| * 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' |
| id 'com.github.jk1.dependency-license-report' version '1.16' |
| } |
| |
| applyGoNature() |
| |
| evaluationDependsOn(":sdks:java:harness") |
| evaluationDependsOn(":sdks:java:io:kafka") |
| |
| description = "Apache Beam :: SDKs :: Java :: Container" |
| |
| // Disable gogradle's dependency resolution so it uses Go modules instead. |
| installDependencies.enabled = false |
| resolveBuildDependencies.enabled = false |
| resolveTestDependencies.enabled = false |
| |
| configurations { |
| dockerDependency |
| sdkHarnessLauncher |
| } |
| |
| 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 |
| } |
| dockerDependency library.java.slf4j_api |
| dockerDependency library.java.slf4j_jdk14 |
| dockerDependency project(path: ":sdks:java:harness", configuration: "shadow") |
| // For executing KafkaIO, e.g. as an external transform |
| dockerDependency project(":sdks:java:io:kafka") |
| // This dependency is set to 'provided' scope in :sdks:java:io:kafka |
| dockerDependency library.java.kafka_clients |
| } |
| |
| golang { |
| packagePath = 'github.com/apache/beam/sdks/v2/java/container' |
| goBuild { |
| // TODO(herohde): build local platform + linux-amd64, if possible. |
| targetPlatform = ['linux-amd64'] |
| outputLocation = './build/target/${GOOS}_${GOARCH}/boot' |
| } |
| } |
| |
| // command: ./gradlew generateLicenseReport |
| import com.github.jk1.license.render.* |
| licenseReport { |
| projects = [project, |
| project.rootProject.findProject(':sdks:java:harness'), |
| project.rootProject.findProject(':sdks:java:io:kafka')] |
| excludeOwnGroup = true |
| excludeGroups = ["beam.*"] // project dependencies do not match their maven coords |
| configurations = ALL |
| renderers = [new JsonReportRenderer()] |
| } |
| |
| task pullLicenses(type: Exec) { |
| dependsOn generateLicenseReport |
| generateLicenseReport.outputs.cacheIf { false } |
| |
| commandLine './license_scripts/license_script.sh' |
| outputs.dir('build/target/third_party_licenses') |
| outputs.dir('build/target/java_third_party_licenses') |
| } |
| |
| task downloadCloudProfilerAgent(type: Exec) { |
| executable "sh" |
| args "-c", "wget -q -O- https://storage.googleapis.com/cloud-profiler/java/latest/profiler_java_agent.tar.gz | tar xzv -C build/target/profiler/" |
| outputs.dir('build/target/profiler') |
| } |
| |
| artifacts { |
| sdkHarnessLauncher file: file('./build/target'), builtBy: goBuild |
| } |
| |
| task pushAll { |
| dependsOn ":sdks:java:container:java8:dockerPush" |
| dependsOn ":sdks:java:container:java11:dockerPush" |
| } |