blob: ab1037ccad052ce9c4908e7b9e97c38fa5413d2b [file] [log] [blame] [edit]
# Copyright 2020 The Fuchsia Authors. All rights reserved.
# Use of this source code is governed by a BSD-style license that can be
# found in the LICENSE file.
import("//build/components.gni")
import("//sdk/ctf/build/internal/ctf_element.gni")
import("//sdk/ctf/build/internal/ctf_version.gni")
import("//sdk/ctf/build/internal/write_ctf_file.gni")
# Creates a FAR archive from a ctf_fuchsia_package_archive target.
#
# Parameters
# package
# The fuchsia_package target to archive. This must be declared in the same file.
# Type: label
#
# package_name
# The name of the fuchsia_package to archive.
# This is also used as the archive name.
# Type: string
template("ctf_fuchsia_package_archive") {
assert(defined(invoker.package),
"you must specify a package target to archive")
assert(defined(invoker.package_name),
"you must specify the name of the package to archive")
archive_name = invoker.package_name
archive_target = "${target_name}_archive"
fuchsia_package_archive(archive_target) {
testonly = true
package = invoker.package
archive_name = archive_name
}
copy_target = "${target_name}_copy"
copy(copy_target) {
testonly = true
sources = get_target_outputs(":$archive_target")
outputs = [ "$root_out_dir/cts/{{source_file_part}}" ]
deps = [ ":$archive_target" ]
}
group(target_name) {
testonly = true
deps = [ ":$copy_target" ]
metadata = {
_ctf_artifacts = get_target_outputs(":$copy_target")
ctf_artifacts = rebase_path(_ctf_artifacts, root_out_dir)
# For usage, see generate_ctf_packages.gni and generate_ctf_tests.gni
package_archives = [
{
archive_name = archive_name
package_name = invoker.package_name
archive_gn_label =
get_label_info(":$copy_target", "label_no_toolchain")
},
]
}
}
}
# A Fuchsia package that can be used in CTF.
#
# An equivalent to fuchsia_package, but ensures dependencies are allowed in CTF.
# To build a FAR archive of this package, depend on ${target_name}_archive.
template("ctf_fuchsia_package") {
assert(defined(invoker.package_name), "package_name must be defined.")
main_target_name = target_name
if (!defined(invoker.deps)) {
invoker.deps = []
}
if (invoker.deps != [] && cts_version == "") {
verify_target = target_name + "_verify_deps"
}
write_file_target = target_name + "_ctf_file"
if (defined(verify_target)) {
ctf_element(verify_target) {
deps_to_verify = invoker.deps
invoker_label =
get_label_info(":${invoker.target_name}", "label_no_toolchain")
}
}
write_ctf_file(write_file_target) {
}
fuchsia_package(target_name) {
forward_variables_from(invoker, "*")
if (defined(verify_target)) {
deps += [ ":$verify_target" ]
}
deps += [ ":$write_file_target" ]
}
# Optional FAR archive that can be released in CTF.
ctf_fuchsia_package_archive("${target_name}_archive") {
package = ":$main_target_name"
package_name = invoker.package_name
}
}