# Copyright 2015 The Chromium Authors. All rights reserved. # Use of this source code is governed by a BSD-style license that can be # found in the LICENSE file. # ============================================================================== # TEST SETUP # ============================================================================== template("_gen_isolate") { testonly = true _runtime_deps_file = "$target_gen_dir/$target_name.runtime_deps" group("${target_name}__write_deps") { forward_variables_from(invoker, [ "data", "data_deps", "deps", "public_deps", ]) write_runtime_deps = _runtime_deps_file } action(target_name) { script = "//testing/generate_isolate.py" inputs = [ _runtime_deps_file, ] outputs = [ invoker.output, ] args = [ "--output-directory=.", "--out-file", rebase_path(invoker.output, root_build_dir), "--runtime-deps-file", rebase_path(_runtime_deps_file, root_build_dir), ] if (is_android) { args += [ "--apply-android-filters" ] } if (defined(invoker.apply_device_filters) && invoker.apply_device_filters) { args += [ "--apply-device-filters" ] } _assert_no_odd_data = defined(invoker.assert_no_odd_data) && invoker.assert_no_odd_data if (_assert_no_odd_data) { args += [ "--assert-no-odd-data" ] } if (defined(invoker.command)) { _isolate_dir = get_path_info(invoker.output, "dir") args += [ "--command", rebase_path(invoker.command, _isolate_dir), ] } deps = [ ":${invoker.target_name}__write_deps", ] } } # Define a test as an executable (or apk on Android) with the "testonly" flag # set. # Variable: # use_raw_android_executable: Use executable() rather than android_apk(). # use_native_activity: Test implements ANativeActivity_onCreate(). template("test") { if (is_android) { import("//build/config/android/config.gni") import("//build/config/android/rules.gni") import("//build/config/sanitizers/sanitizers.gni") _use_raw_android_executable = defined(invoker.use_raw_android_executable) && invoker.use_raw_android_executable # output_name is used to allow targets with the same name but in different # packages to still produce unique runner scripts. _output_name = invoker.target_name if (defined(invoker.output_name)) { _output_name = invoker.output_name } _test_runner_target = "${_output_name}__test_runner_script" _wrapper_script_vars = [ "shard_timeout" ] _gen_isolate_vars = [ "allow_odd_runtime_deps", "ignore_all_data_deps", ] _generate_device_isolate = !defined(invoker.ignore_all_data_deps) || !invoker.ignore_all_data_deps if (_generate_device_isolate) { _allow_odd_runtime_deps = defined(invoker.allow_odd_runtime_deps) && invoker.allow_odd_runtime_deps # The device isolate is needed at runtime, so it cannot go in # target_gen_dir, as builder/tester configurations do not include it. _target_dir_name = get_label_info(":$target_name", "dir") _device_isolate_path = "$root_out_dir/gen.runtime/$_target_dir_name/$target_name.device.isolate" _gen_isolate_target_name = "${target_name}__isolate" _gen_isolate(_gen_isolate_target_name) { forward_variables_from(invoker, [ "data", "data_deps", "deps", "public_deps", ]) assert_no_odd_data = !_allow_odd_runtime_deps output = _device_isolate_path apply_device_filters = true } } assert(_use_raw_android_executable || enable_java_templates) if (_use_raw_android_executable) { _exec_target = "${target_name}__exec" _dist_target = "${target_name}__dist" _exec_output = "$target_out_dir/${invoker.target_name}/${invoker.target_name}" executable(_exec_target) { # Configs will always be defined since we set_defaults in BUILDCONFIG.gn. configs = [] data_deps = [] forward_variables_from( invoker, "*", _wrapper_script_vars + _gen_isolate_vars + [ "extra_dist_files" ]) testonly = true # Thanks to the set_defaults() for test(), configs are initialized with # the default shared_library configs rather than executable configs. configs -= [ "//build/config:shared_library_config", "//build/config/android:hide_native_jni_exports", ] configs += [ "//build/config:executable_config" ] # Don't output to the root or else conflict with the group() below. output_name = rebase_path(_exec_output, root_out_dir) if (is_component_build || is_asan) { data_deps += [ "//build/android:cpplib_stripped" ] } } create_native_executable_dist(_dist_target) { testonly = true dist_dir = "$root_out_dir/$target_name" binary = _exec_output deps = [ ":$_exec_target", ] if (defined(invoker.extra_dist_files)) { extra_files = invoker.extra_dist_files } } } else { _library_target = "_${target_name}__library" _apk_target = "${target_name}_apk" _apk_specific_vars = [ "android_manifest", "enable_multidex", "proguard_configs", "proguard_enabled", "use_default_launcher", "write_asset_list", "use_native_activity", ] shared_library(_library_target) { # Configs will always be defined since we set_defaults in BUILDCONFIG.gn. configs = [] # Prevent list overwriting warning. configs = invoker.configs testonly = true deps = [] forward_variables_from(invoker, "*", _apk_specific_vars + _wrapper_script_vars + _gen_isolate_vars + [ "visibility" ]) if (!defined(invoker.use_default_launcher) || invoker.use_default_launcher) { deps += [ "//testing/android/native_test:native_test_native_code" ] } } unittest_apk(_apk_target) { forward_variables_from(invoker, _apk_specific_vars + [ "deps" ]) unittests_dep = ":$_library_target" apk_name = invoker.target_name if (defined(invoker.output_name)) { apk_name = invoker.output_name unittests_binary = "lib${apk_name}.so" install_script_name = "install_${invoker.output_name}" } deps += [ ":$_library_target" ] # TODO(agrieve): Remove this data_dep once bots don't build the _apk # target (post-GYP). # It's a bit backwards for the apk to depend on the runner script, since # the apk is conceptually a runtime_dep of the script. However, it is # currently necessary because the bots build this _apk target directly # rather than the group() below. data_deps = [ ":$_test_runner_target", ] } # Incremental test targets work only for .apks. _incremental_test_runner_target = "${_output_name}_incremental__test_runner_script" test_runner_script(_incremental_test_runner_target) { forward_variables_from(invoker, _wrapper_script_vars) if (_generate_device_isolate) { isolate_file = _device_isolate_path deps = [ ":$_gen_isolate_target_name", ] } apk_target = ":$_apk_target" test_name = "${_output_name}_incremental" test_type = "gtest" test_suite = _output_name incremental_install = true } group("${target_name}_incremental") { testonly = true datadeps = [ ":$_incremental_test_runner_target", ] deps = [ ":${_apk_target}_incremental", ] } } _test_runner_target = "${_output_name}__test_runner_script" test_runner_script(_test_runner_target) { forward_variables_from(invoker, _wrapper_script_vars) if (_generate_device_isolate) { isolate_file = _device_isolate_path deps = [ ":$_gen_isolate_target_name", ] } if (_use_raw_android_executable) { executable_dist_dir = "$root_out_dir/$_dist_target" } else { apk_target = ":$_apk_target" } test_name = _output_name test_type = "gtest" test_suite = _output_name } group(target_name) { testonly = true deps = [ ":$_test_runner_target", ] if (_use_raw_android_executable) { deps += [ ":$_dist_target" ] } else { deps += [ ":$_apk_target" ] } } # TODO(GYP_GONE): Delete this after we've converted everything to GN. # The _run targets exist only for compatibility w/ GYP. group("${target_name}_apk_run") { testonly = true deps = [ ":${invoker.target_name}", ] } } else if (is_ios) { import("//build/config/ios/rules.gni") _test_target = target_name _resources_bundle_data = target_name + "_resources_bundle_data" bundle_data(_resources_bundle_data) { visibility = [ ":${_test_target}", ":${_test_target}_generate_executable", ] sources = [ "//testing/gtest_ios/Default.png", ] outputs = [ "{{bundle_resources_dir}}/{{source_file_part}}", ] } ios_app_bundle(_test_target) { testonly = true # See above call. set_sources_assignment_filter([]) forward_variables_from(invoker, "*", [ "testonly" ]) # Provide sensible defaults in case invoker did not define any of those # required variables. if (!defined(info_plist) && !defined(info_plist_target)) { info_plist = "//testing/gtest_ios/unittest-Info.plist" } if (!defined(entitlements_path)) { entitlements_path = "//testing/gtest_ios" } if (!defined(code_signing_identity)) { code_signing_identity = "" } # TODO(crbug.com/603102): remove this once gyp support is dropped and all # application uses the target name as value for BUNDLE_ID_TEST_NAME. if (defined(invoker.app_name)) { app_name = invoker.app_name } else { app_name = target_name } if (!defined(extra_substitutions)) { extra_substitutions = [] } extra_substitutions += [ "BUNDLE_ID_TEST_NAME=$app_name" ] if (!defined(deps)) { deps = [] } deps += [ ":$_resources_bundle_data", # All shared libraries must have the sanitizer deps to properly link in # asan mode (this target will be empty in other cases). "//build/config/sanitizers:deps", ] } } else { executable(target_name) { deps = [] forward_variables_from(invoker, "*") testonly = true deps += [ # All shared libraries must have the sanitizer deps to properly link in # asan mode (this target will be empty in other cases). "//build/config/sanitizers:deps", # Give tests the default manifest on Windows (a no-op elsewhere). "//build/win:default_exe_manifest", ] } # TODO(GYP_GONE): Delete this after we've converted everything to GN. # The _run targets exist only for compatibility with GYP. group("${target_name}_run") { testonly = true deps = [ ":${invoker.target_name}", ] } if (defined(invoker.output_name) && target_name != invoker.output_name) { group("${invoker.output_name}_run") { testonly = true deps = [ ":${invoker.target_name}", ] } } } }