blob: 84b4f0dad7f3b7884d2fcb4707a539010f1540da [file] [log] [blame]
# 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("//sdk/cts/build/cts_element.gni")
import("//sdk/cts/build/cts_vars.gni")
# An executable that can be used in CTS.
#
# An equivalent to the built-in executable, but ensures dependencies are allowed
# in CTS.
#
# Example:
# ```
# cts_executable("my-test") {
# deps = [ "//zircon/public/lib/zxtest" ]
# sources = [ "//sdk/cts/tests/my_test/my_test.cc" ]
# testonly = true
# }
# ```
#
# Parameters
# sources (required)
# List of files to create an executable from.
# Type: list(labels)
template("cts_executable") {
assert(defined(invoker.sources), "Sources must be defined.")
if (defined(invoker.deps) && invoker.deps != []) {
cts_element("${target_name}_verify_deps") {
deps = invoker.deps
invoker_label = get_label_info(invoker.target_name, "label_no_toolchain")
}
}
executable(target_name) {
forward_variables_from(invoker, "*")
if (defined(deps) && deps != []) {
deps += [ ":${target_name}_verify_deps" ]
}
}
# Creates a file to enable other CTS targets to depend on this test package.
target_build_dir = get_label_info(":$target_name", "dir")
target_build_dir = string_replace(target_build_dir, "//", "/")
write_file(
"${root_build_dir}/cts/${target_build_dir}/${target_name}.${cts_extension}",
"true")
}
set_defaults("cts_executable") {
configs = default_executable_configs
}