/* * Copyright 2018 The Android Open Source Project * * Licensed 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. */ package androidx.build import androidx.build.gradle.isRoot import java.io.File import org.gradle.api.Project import org.gradle.api.file.Directory import org.gradle.api.file.RegularFile import org.gradle.api.provider.Provider /** * @return build id string for current build * * The build server does not pass the build id so we infer it from the last folder of the * distribution directory name. */ fun getBuildId(): String { return if (System.getenv("BUILD_NUMBER") != null) { System.getenv("BUILD_NUMBER") } else { "0" } } /** * Gets set to true when the build id is prefixed with P. * * In AffectedModuleDetector, we return a different ProjectSubset in presubmit vs. postsubmit, to * get the desired test behaviors. */ fun isPresubmitBuild(): Boolean { return if (System.getenv("BUILD_NUMBER") != null) { System.getenv("BUILD_NUMBER").startsWith("P") } else { false } } /** * The DIST_DIR is where you want to save things from the build. The build server will copy the * contents of DIST_DIR to somewhere and make it available. */ fun Project.getDistributionDirectory(): File { val envVar = project.providers.environmentVariable("DIST_DIR").getOrElse("") return if (envVar != "") { File(envVar) } else { // Subdirectory of out directory (an ancestor of all files generated by the build) File(getOutDirectory(), "dist") } .also { distDir -> distDir.mkdirs() } } fun Project.getOutDirectory(): File = extensions.extraProperties.get("outDir") as File /** Directory to put build info files for release service dependency files. */ fun Project.getBuildInfoDirectory(): File = File(getDistributionDirectory(), "build-info") /** * Directory for android test configuration files that get consumed by Tradefed in CI. These configs * cause all the tests to be run, except in cases where buildSrc changes. */ fun Project.getTestConfigDirectory(): Provider = rootProject.layout.buildDirectory.dir("test-xml-configs") /** Directory for App APKs (from ApkOutputProviders) used in device tests. */ fun Project.getAppApksFilesDirectory(): Provider = rootProject.layout.buildDirectory.dir("app-apks-files") /** A file within [getTestConfigDirectory] */ fun Project.getFileInTestConfigDirectory(name: String): Provider = getTestConfigDirectory().map { it.file(name) } /** Directory to put host test results so they can be consumed by the testing dashboard. */ fun Project.getHostTestResultDirectory(): File = File(getDistributionDirectory(), "host-test-reports") /** Whether the build should force all versions to be snapshots. */ fun isSnapshotBuild() = System.getenv("SNAPSHOT") != null /** Directory in a maven format to put all the publishing libraries. */ fun Project.getRepositoryDirectory(): File { val actualRootProject = if (project.isRoot) project else project.rootProject val directory = if (isSnapshotBuild()) { // For snapshot builds we put artifacts directly where downstream users can find them. File(actualRootProject.getDistributionDirectory(), "repository") } else { File(getOutDirectory(), "repository") } directory.mkdirs() return directory } /** Directory in a maven format to put per project publishing artifacts. */ fun Project.getPerProjectRepositoryDirectory(): Provider = project.layout.buildDirectory.dir("repository")