wjia@webrtc.org | 03cfde2 | 2014-01-14 17:48:34 +0000 | [diff] [blame] | 1 | # Copyright (c) 2014 The WebRTC project authors. All Rights Reserved. |
| 2 | # |
| 3 | # Use of this source code is governed by a BSD-style license |
| 4 | # that can be found in the LICENSE file in the root of the source |
| 5 | # tree. An additional intellectual property rights grant can be found |
| 6 | # in the file PATENTS. All contributing project authors may |
| 7 | # be found in the AUTHORS file in the root of the source tree. |
| 8 | |
Patrik Höglund | 29dd6d7 | 2017-12-01 11:35:26 +0100 | [diff] [blame] | 9 | # This is the root build file for GN. GN will start processing by loading this |
| 10 | # file, and recursively load all dependencies until all dependencies are either |
| 11 | # resolved or known not to exist (which will cause the build to fail). So if |
| 12 | # you add a new build file, there must be some path of dependencies from this |
| 13 | # file to your new one or GN won't know about it. |
| 14 | |
Mirko Bonadei | bb54720 | 2017-09-15 06:15:48 +0200 | [diff] [blame] | 15 | import("//build/config/linux/pkg_config.gni") |
| 16 | import("//build/config/sanitizers/sanitizers.gni") |
| 17 | import("webrtc.gni") |
Dan Minor | 9c68613 | 2018-01-15 10:20:00 -0500 | [diff] [blame] | 18 | if (!build_with_mozilla) { |
| 19 | import("//third_party/protobuf/proto_library.gni") |
| 20 | } |
Mirko Bonadei | bb54720 | 2017-09-15 06:15:48 +0200 | [diff] [blame] | 21 | if (is_android) { |
| 22 | import("//build/config/android/config.gni") |
| 23 | import("//build/config/android/rules.gni") |
| 24 | } |
ehmaldonado | 37d7a22 | 2016-11-08 06:34:20 -0800 | [diff] [blame] | 25 | |
Mirko Bonadei | bb54720 | 2017-09-15 06:15:48 +0200 | [diff] [blame] | 26 | if (!build_with_chromium) { |
Patrik Höglund | 29dd6d7 | 2017-12-01 11:35:26 +0100 | [diff] [blame] | 27 | # This target should (transitively) cause everything to be built; if you run |
| 28 | # 'ninja default' and then 'ninja all', the second build should do no work. |
Mirko Bonadei | bb54720 | 2017-09-15 06:15:48 +0200 | [diff] [blame] | 29 | group("default") { |
| 30 | testonly = true |
| 31 | deps = [ |
| 32 | ":webrtc", |
Mirko Bonadei | bb54720 | 2017-09-15 06:15:48 +0200 | [diff] [blame] | 33 | ] |
Joachim Bauch | 93e9134 | 2017-12-07 01:25:53 +0100 | [diff] [blame] | 34 | if (rtc_build_examples) { |
| 35 | deps += [ "examples" ] |
| 36 | } |
| 37 | if (rtc_build_tools) { |
| 38 | deps += [ "rtc_tools" ] |
| 39 | } |
Mirko Bonadei | bb54720 | 2017-09-15 06:15:48 +0200 | [diff] [blame] | 40 | if (rtc_include_tests) { |
Patrik Höglund | 29dd6d7 | 2017-12-01 11:35:26 +0100 | [diff] [blame] | 41 | deps += [ |
| 42 | ":rtc_unittests", |
| 43 | ":video_engine_tests", |
| 44 | ":webrtc_nonparallel_tests", |
| 45 | ":webrtc_perf_tests", |
| 46 | "common_audio:common_audio_unittests", |
| 47 | "common_video:common_video_unittests", |
| 48 | "media:rtc_media_unittests", |
| 49 | "modules:modules_tests", |
| 50 | "modules:modules_unittests", |
| 51 | "modules/audio_coding:audio_coding_tests", |
| 52 | "modules/audio_processing:audio_processing_tests", |
| 53 | "modules/remote_bitrate_estimator:bwe_simulations_tests", |
| 54 | "modules/rtp_rtcp:test_packet_masks_metrics", |
| 55 | "modules/video_capture:video_capture_internal_impl", |
| 56 | "ortc:ortc_unittests", |
| 57 | "pc:peerconnection_unittests", |
| 58 | "pc:rtc_pc_unittests", |
| 59 | "rtc_base:rtc_base_tests_utils", |
| 60 | "stats:rtc_stats_unittests", |
| 61 | "system_wrappers:system_wrappers_unittests", |
| 62 | "test", |
| 63 | "video:screenshare_loopback", |
Ilya Nikolaevskiy | 255d1cd | 2017-12-21 18:02:59 +0100 | [diff] [blame] | 64 | "video:sv_loopback", |
Patrik Höglund | 29dd6d7 | 2017-12-01 11:35:26 +0100 | [diff] [blame] | 65 | "video:video_loopback", |
Patrik Höglund | 29dd6d7 | 2017-12-01 11:35:26 +0100 | [diff] [blame] | 66 | ] |
| 67 | if (is_android) { |
| 68 | deps += [ |
| 69 | ":android_junit_tests", |
| 70 | "sdk/android:libjingle_peerconnection_android_unittest", |
| 71 | ] |
| 72 | } else { |
| 73 | deps += [ "modules/video_capture:video_capture_tests" ] |
| 74 | } |
| 75 | if (rtc_enable_protobuf) { |
| 76 | deps += [ |
| 77 | "audio:low_bandwidth_audio_test", |
| 78 | "logging:rtc_event_log2rtp_dump", |
| 79 | ] |
| 80 | } |
Mirko Bonadei | bb54720 | 2017-09-15 06:15:48 +0200 | [diff] [blame] | 81 | } |
| 82 | } |
| 83 | } |
| 84 | |
| 85 | # Contains the defines and includes in common.gypi that are duplicated both as |
| 86 | # target_defaults and direct_dependent_settings. |
| 87 | config("common_inherited_config") { |
| 88 | defines = [] |
| 89 | cflags = [] |
| 90 | ldflags = [] |
| 91 | if (build_with_mozilla) { |
| 92 | defines += [ "WEBRTC_MOZILLA_BUILD" ] |
| 93 | } |
| 94 | |
| 95 | # Some tests need to declare their own trace event handlers. If this define is |
| 96 | # not set, the first time TRACE_EVENT_* is called it will store the return |
| 97 | # value for the current handler in an static variable, so that subsequent |
| 98 | # changes to the handler for that TRACE_EVENT_* will be ignored. |
| 99 | # So when tests are included, we set this define, making it possible to use |
| 100 | # different event handlers in different tests. |
ehmaldonado | 37d7a22 | 2016-11-08 06:34:20 -0800 | [diff] [blame] | 101 | if (rtc_include_tests) { |
Mirko Bonadei | bb54720 | 2017-09-15 06:15:48 +0200 | [diff] [blame] | 102 | defines += [ "WEBRTC_NON_STATIC_TRACE_EVENT_HANDLERS=1" ] |
| 103 | } else { |
| 104 | defines += [ "WEBRTC_NON_STATIC_TRACE_EVENT_HANDLERS=0" ] |
| 105 | } |
| 106 | if (build_with_chromium) { |
| 107 | defines += [ |
| 108 | # TODO(kjellander): Cleanup unused ones and move defines closer to |
| 109 | # the source when webrtc:4256 is completed. |
Mirko Bonadei | bb54720 | 2017-09-15 06:15:48 +0200 | [diff] [blame] | 110 | "GTEST_RELATIVE_PATH", |
| 111 | "WEBRTC_CHROMIUM_BUILD", |
| 112 | ] |
| 113 | include_dirs = [ |
| 114 | # The overrides must be included first as that is the mechanism for |
| 115 | # selecting the override headers in Chromium. |
| 116 | "../webrtc_overrides", |
| 117 | |
| 118 | # Allow includes to be prefixed with webrtc/ in case it is not an |
| 119 | # immediate subdirectory of the top-level. |
| 120 | ".", |
| 121 | ] |
| 122 | } |
Fabrice de Gans-Riberi | 09a6cd5 | 2018-03-30 10:38:06 -0700 | [diff] [blame] | 123 | if (is_posix || is_fuchsia) { |
Mirko Bonadei | bb54720 | 2017-09-15 06:15:48 +0200 | [diff] [blame] | 124 | defines += [ "WEBRTC_POSIX" ] |
| 125 | } |
| 126 | if (is_ios) { |
| 127 | defines += [ |
| 128 | "WEBRTC_MAC", |
| 129 | "WEBRTC_IOS", |
| 130 | ] |
| 131 | } |
| 132 | if (is_linux) { |
| 133 | defines += [ "WEBRTC_LINUX" ] |
| 134 | } |
| 135 | if (is_mac) { |
| 136 | defines += [ "WEBRTC_MAC" ] |
| 137 | } |
Sergey Ulanov | 6acefdb | 2017-12-11 17:38:13 -0800 | [diff] [blame] | 138 | if (is_fuchsia) { |
| 139 | defines += [ "WEBRTC_FUCHSIA" ] |
| 140 | } |
Mirko Bonadei | bb54720 | 2017-09-15 06:15:48 +0200 | [diff] [blame] | 141 | if (is_win) { |
Mirko Bonadei | 89a8774 | 2018-04-24 09:12:13 +0200 | [diff] [blame] | 142 | defines += [ "WEBRTC_WIN" ] |
Mirko Bonadei | bb54720 | 2017-09-15 06:15:48 +0200 | [diff] [blame] | 143 | } |
| 144 | if (is_android) { |
| 145 | defines += [ |
| 146 | "WEBRTC_LINUX", |
| 147 | "WEBRTC_ANDROID", |
| 148 | ] |
Dan Minor | 9c68613 | 2018-01-15 10:20:00 -0500 | [diff] [blame] | 149 | |
| 150 | if (build_with_mozilla) { |
| 151 | defines += [ "WEBRTC_ANDROID_OPENSLES" ] |
| 152 | } |
Mirko Bonadei | bb54720 | 2017-09-15 06:15:48 +0200 | [diff] [blame] | 153 | } |
| 154 | if (is_chromeos) { |
| 155 | defines += [ "CHROMEOS" ] |
| 156 | } |
| 157 | |
| 158 | if (rtc_sanitize_coverage != "") { |
| 159 | assert(is_clang, "sanitizer coverage requires clang") |
| 160 | cflags += [ "-fsanitize-coverage=${rtc_sanitize_coverage}" ] |
| 161 | ldflags += [ "-fsanitize-coverage=${rtc_sanitize_coverage}" ] |
| 162 | } |
| 163 | |
| 164 | if (is_ubsan) { |
| 165 | cflags += [ "-fsanitize=float-cast-overflow" ] |
| 166 | } |
Mirko Bonadei | bb54720 | 2017-09-15 06:15:48 +0200 | [diff] [blame] | 167 | } |
| 168 | |
| 169 | config("common_config") { |
| 170 | cflags = [] |
Mirko Bonadei | d757356 | 2018-03-19 16:23:48 +0100 | [diff] [blame] | 171 | cflags_c = [] |
Mirko Bonadei | bb54720 | 2017-09-15 06:15:48 +0200 | [diff] [blame] | 172 | cflags_cc = [] |
Mirko Bonadei | d757356 | 2018-03-19 16:23:48 +0100 | [diff] [blame] | 173 | cflags_objc = [] |
Mirko Bonadei | bb54720 | 2017-09-15 06:15:48 +0200 | [diff] [blame] | 174 | defines = [] |
| 175 | |
| 176 | if (rtc_enable_protobuf) { |
| 177 | defines += [ "WEBRTC_ENABLE_PROTOBUF=1" ] |
| 178 | } else { |
| 179 | defines += [ "WEBRTC_ENABLE_PROTOBUF=0" ] |
| 180 | } |
| 181 | |
Mirko Bonadei | bb54720 | 2017-09-15 06:15:48 +0200 | [diff] [blame] | 182 | if (rtc_include_internal_audio_device) { |
| 183 | defines += [ "WEBRTC_INCLUDE_INTERNAL_AUDIO_DEVICE" ] |
| 184 | } |
| 185 | |
| 186 | if (!rtc_libvpx_build_vp9) { |
| 187 | defines += [ "RTC_DISABLE_VP9" ] |
| 188 | } |
| 189 | |
| 190 | if (rtc_enable_sctp) { |
| 191 | defines += [ "HAVE_SCTP" ] |
| 192 | } |
| 193 | |
| 194 | if (rtc_enable_external_auth) { |
| 195 | defines += [ "ENABLE_EXTERNAL_AUTH" ] |
| 196 | } |
| 197 | |
Anders Carlsson | dd8c165 | 2018-01-30 10:32:13 +0100 | [diff] [blame] | 198 | if (rtc_use_builtin_sw_codecs) { |
| 199 | defines += [ "USE_BUILTIN_SW_CODECS" ] |
| 200 | } |
| 201 | |
Mirko Bonadei | bb54720 | 2017-09-15 06:15:48 +0200 | [diff] [blame] | 202 | if (build_with_chromium) { |
| 203 | defines += [ |
| 204 | # NOTICE: Since common_inherited_config is used in public_configs for our |
| 205 | # targets, there's no point including the defines in that config here. |
| 206 | # TODO(kjellander): Cleanup unused ones and move defines closer to the |
| 207 | # source when webrtc:4256 is completed. |
| 208 | "HAVE_WEBRTC_VIDEO", |
| 209 | "HAVE_WEBRTC_VOICE", |
| 210 | "LOGGING_INSIDE_WEBRTC", |
Mirko Bonadei | bb54720 | 2017-09-15 06:15:48 +0200 | [diff] [blame] | 211 | ] |
| 212 | } else { |
Fabrice de Gans-Riberi | 09a6cd5 | 2018-03-30 10:38:06 -0700 | [diff] [blame] | 213 | if (is_posix || is_fuchsia) { |
Mirko Bonadei | bb54720 | 2017-09-15 06:15:48 +0200 | [diff] [blame] | 214 | # Enable more warnings: -Wextra is currently disabled in Chromium. |
| 215 | cflags = [ |
| 216 | "-Wextra", |
| 217 | |
| 218 | # Repeat some flags that get overridden by -Wextra. |
| 219 | "-Wno-unused-parameter", |
| 220 | "-Wno-missing-field-initializers", |
Mirko Bonadei | bb54720 | 2017-09-15 06:15:48 +0200 | [diff] [blame] | 221 | ] |
Mirko Bonadei | d757356 | 2018-03-19 16:23:48 +0100 | [diff] [blame] | 222 | cflags_c += [ |
| 223 | # TODO(bugs.webrtc.org/9029): enable commented compiler flags. |
| 224 | # Some of these flags should also be added to cflags_objc. |
| 225 | |
| 226 | # "-Wextra", (used when building C++ but not when building C) |
| 227 | # "-Wmissing-prototypes", (C/Obj-C only) |
| 228 | # "-Wmissing-declarations", (ensure this is always used C/C++, etc..) |
| 229 | "-Wstrict-prototypes", |
| 230 | |
| 231 | # "-Wpointer-arith", (ensure this is always used C/C++, etc..) |
| 232 | # "-Wbad-function-cast", (C/Obj-C only) |
| 233 | # "-Wnested-externs", (C/Obj-C only) |
| 234 | ] |
| 235 | cflags_objc += [ "-Wstrict-prototypes" ] |
Mirko Bonadei | bb54720 | 2017-09-15 06:15:48 +0200 | [diff] [blame] | 236 | cflags_cc = [ |
| 237 | "-Wnon-virtual-dtor", |
| 238 | |
| 239 | # This is enabled for clang; enable for gcc as well. |
| 240 | "-Woverloaded-virtual", |
| 241 | ] |
| 242 | } |
| 243 | |
| 244 | if (is_clang) { |
| 245 | cflags += [ |
| 246 | "-Wc++11-narrowing", |
| 247 | "-Wimplicit-fallthrough", |
| 248 | "-Wthread-safety", |
| 249 | "-Winconsistent-missing-override", |
| 250 | "-Wundef", |
| 251 | ] |
| 252 | |
| 253 | # use_xcode_clang only refers to the iOS toolchain, host binaries use |
| 254 | # chromium's clang always. |
| 255 | if (!is_nacl && |
| 256 | (!use_xcode_clang || current_toolchain == host_toolchain)) { |
| 257 | # Flags NaCl (Clang 3.7) and Xcode 7.3 (Clang clang-703.0.31) do not |
| 258 | # recognize. |
| 259 | cflags += [ "-Wunused-lambda-capture" ] |
| 260 | } |
| 261 | } |
Mirko Bonadei | e7659df | 2018-05-16 11:50:40 +0200 | [diff] [blame] | 262 | |
| 263 | if (is_win && !is_clang) { |
| 264 | # MSVC warning suppressions (needed to use Abseil). |
| 265 | # TODO(bugs.webrtc.org/9274): Remove these warnings as soon as MSVC allows |
| 266 | # external headers warning suppression (or fix them upstream). |
| 267 | cflags += [ "/wd4702" ] # unreachable code |
| 268 | } |
Mirko Bonadei | bb54720 | 2017-09-15 06:15:48 +0200 | [diff] [blame] | 269 | } |
| 270 | |
| 271 | if (current_cpu == "arm64") { |
| 272 | defines += [ "WEBRTC_ARCH_ARM64" ] |
| 273 | defines += [ "WEBRTC_HAS_NEON" ] |
| 274 | } |
| 275 | |
| 276 | if (current_cpu == "arm") { |
| 277 | defines += [ "WEBRTC_ARCH_ARM" ] |
| 278 | if (arm_version >= 7) { |
| 279 | defines += [ "WEBRTC_ARCH_ARM_V7" ] |
| 280 | if (arm_use_neon) { |
| 281 | defines += [ "WEBRTC_HAS_NEON" ] |
| 282 | } |
| 283 | } |
| 284 | } |
| 285 | |
| 286 | if (current_cpu == "mipsel") { |
| 287 | defines += [ "MIPS32_LE" ] |
| 288 | if (mips_float_abi == "hard") { |
| 289 | defines += [ "MIPS_FPU_LE" ] |
| 290 | } |
| 291 | if (mips_arch_variant == "r2") { |
| 292 | defines += [ "MIPS32_R2_LE" ] |
| 293 | } |
| 294 | if (mips_dsp_rev == 1) { |
| 295 | defines += [ "MIPS_DSP_R1_LE" ] |
| 296 | } else if (mips_dsp_rev == 2) { |
| 297 | defines += [ |
| 298 | "MIPS_DSP_R1_LE", |
| 299 | "MIPS_DSP_R2_LE", |
| 300 | ] |
| 301 | } |
| 302 | } |
| 303 | |
| 304 | if (is_android && !is_clang) { |
| 305 | # The Android NDK doesn"t provide optimized versions of these |
| 306 | # functions. Ensure they are disabled for all compilers. |
| 307 | cflags += [ |
| 308 | "-fno-builtin-cos", |
| 309 | "-fno-builtin-sin", |
| 310 | "-fno-builtin-cosf", |
| 311 | "-fno-builtin-sinf", |
| 312 | ] |
| 313 | } |
| 314 | |
Max Moroz | a61fa6e | 2018-05-28 19:26:58 -0700 | [diff] [blame] | 315 | if (use_fuzzing_engine && optimize_for_fuzzing) { |
Mirko Bonadei | bb54720 | 2017-09-15 06:15:48 +0200 | [diff] [blame] | 316 | # Used in Chromium's overrides to disable logging |
| 317 | defines += [ "WEBRTC_UNSAFE_FUZZER_MODE" ] |
| 318 | } |
| 319 | } |
| 320 | |
| 321 | config("common_objc") { |
| 322 | libs = [ "Foundation.framework" ] |
| 323 | } |
| 324 | |
| 325 | if (!build_with_chromium) { |
| 326 | # Target to build all the WebRTC production code. |
| 327 | rtc_static_library("webrtc") { |
| 328 | # Only the root target should depend on this. |
| 329 | visibility = [ "//:default" ] |
| 330 | |
| 331 | sources = [] |
| 332 | complete_static_lib = true |
Tom Anderson | 36fc5e1 | 2018-03-20 17:36:59 -0700 | [diff] [blame] | 333 | rtc_remove_configs = [ "//build/config/compiler:thin_archive" ] |
Mirko Bonadei | bb54720 | 2017-09-15 06:15:48 +0200 | [diff] [blame] | 334 | defines = [] |
| 335 | |
| 336 | deps = [ |
| 337 | ":webrtc_common", |
Mirko Bonadei | bb54720 | 2017-09-15 06:15:48 +0200 | [diff] [blame] | 338 | "api:transport_api", |
| 339 | "audio", |
| 340 | "call", |
| 341 | "common_audio", |
| 342 | "common_video", |
Mirko Bonadei | bb54720 | 2017-09-15 06:15:48 +0200 | [diff] [blame] | 343 | "media", |
| 344 | "modules", |
| 345 | "modules/video_capture:video_capture_internal_impl", |
| 346 | "ortc", |
Mirko Bonadei | bb54720 | 2017-09-15 06:15:48 +0200 | [diff] [blame] | 347 | "rtc_base", |
| 348 | "sdk", |
Mirko Bonadei | bb54720 | 2017-09-15 06:15:48 +0200 | [diff] [blame] | 349 | "system_wrappers:system_wrappers_default", |
| 350 | "video", |
Mirko Bonadei | bb54720 | 2017-09-15 06:15:48 +0200 | [diff] [blame] | 351 | ] |
| 352 | |
Dan Minor | 9c68613 | 2018-01-15 10:20:00 -0500 | [diff] [blame] | 353 | if (build_with_mozilla) { |
| 354 | deps += [ |
Niels Möller | c6ce9c5 | 2018-05-11 11:15:30 +0200 | [diff] [blame] | 355 | "api/video:video_frame", |
Dan Minor | 9c68613 | 2018-01-15 10:20:00 -0500 | [diff] [blame] | 356 | "system_wrappers:field_trial_default", |
| 357 | "system_wrappers:metrics_default", |
| 358 | ] |
| 359 | } else { |
| 360 | deps += [ |
| 361 | "api", |
| 362 | "logging", |
| 363 | "p2p", |
| 364 | "pc", |
| 365 | "stats", |
| 366 | ] |
| 367 | } |
| 368 | |
Mirko Bonadei | bb54720 | 2017-09-15 06:15:48 +0200 | [diff] [blame] | 369 | if (rtc_enable_protobuf) { |
| 370 | defines += [ "ENABLE_RTC_EVENT_LOG" ] |
| 371 | deps += [ "logging:rtc_event_log_proto" ] |
| 372 | } |
| 373 | } |
Mirko Bonadei | bb54720 | 2017-09-15 06:15:48 +0200 | [diff] [blame] | 374 | } |
| 375 | |
Patrik Höglund | 3e11343 | 2017-12-15 14:40:10 +0100 | [diff] [blame] | 376 | rtc_source_set("typedefs") { |
| 377 | sources = [ |
| 378 | "typedefs.h", |
| 379 | ] |
Fredrik Solenberg | 500e75b | 2018-05-23 11:49:01 +0200 | [diff] [blame] | 380 | deps = [ |
| 381 | "rtc_base/system:arch", |
| 382 | "rtc_base/system:unused", |
| 383 | ] |
Patrik Höglund | 3e11343 | 2017-12-15 14:40:10 +0100 | [diff] [blame] | 384 | } |
| 385 | |
Mirko Bonadei | bb54720 | 2017-09-15 06:15:48 +0200 | [diff] [blame] | 386 | rtc_static_library("webrtc_common") { |
Mirko Bonadei | bb54720 | 2017-09-15 06:15:48 +0200 | [diff] [blame] | 387 | sources = [ |
| 388 | "common_types.cc", |
| 389 | "common_types.h", |
Patrik Höglund | 3e11343 | 2017-12-15 14:40:10 +0100 | [diff] [blame] | 390 | ] |
| 391 | deps = [ |
| 392 | ":typedefs", |
| 393 | "api:array_view", |
| 394 | "api:optional", |
Niels Möller | c6ce9c5 | 2018-05-11 11:15:30 +0200 | [diff] [blame] | 395 | "api/video:video_bitrate_allocation", |
Patrik Höglund | 3e11343 | 2017-12-15 14:40:10 +0100 | [diff] [blame] | 396 | "rtc_base:checks", |
| 397 | "rtc_base:deprecation", |
| 398 | "rtc_base:stringutils", |
Mirko Bonadei | bb54720 | 2017-09-15 06:15:48 +0200 | [diff] [blame] | 399 | ] |
| 400 | |
| 401 | if (!build_with_chromium && is_clang) { |
| 402 | # Suppress warnings from the Chromium Clang plugin (bugs.webrtc.org/163). |
| 403 | suppressed_configs += [ "//build/config/clang:find_bad_constructs" ] |
| 404 | } |
| 405 | } |
| 406 | |
| 407 | if (use_libfuzzer || use_drfuzz || use_afl) { |
| 408 | # This target is only here for gn to discover fuzzer build targets under |
| 409 | # webrtc/test/fuzzers/. |
| 410 | group("webrtc_fuzzers_dummy") { |
| 411 | testonly = true |
| 412 | deps = [ |
| 413 | "test/fuzzers:webrtc_fuzzer_main", |
| 414 | ] |
| 415 | } |
| 416 | } |
| 417 | |
| 418 | if (rtc_include_tests) { |
| 419 | config("rtc_unittests_config") { |
| 420 | # GN orders flags on a target before flags from configs. The default config |
| 421 | # adds -Wall, and this flag have to be after -Wall -- so they need to |
| 422 | # come from a config and can"t be on the target directly. |
| 423 | if (is_clang) { |
| 424 | cflags = [ |
| 425 | "-Wno-sign-compare", |
| 426 | "-Wno-unused-const-variable", |
| 427 | ] |
| 428 | } |
| 429 | } |
| 430 | |
| 431 | rtc_test("rtc_unittests") { |
| 432 | testonly = true |
| 433 | |
| 434 | deps = [ |
| 435 | ":webrtc_common", |
| 436 | "api:rtc_api_unittests", |
Fredrik Solenberg | bbf21a3 | 2018-04-12 22:44:09 +0200 | [diff] [blame] | 437 | "api/audio/test:audio_api_unittests", |
Mirko Bonadei | bb54720 | 2017-09-15 06:15:48 +0200 | [diff] [blame] | 438 | "api/audio_codecs/test:audio_codecs_api_unittests", |
Anders Carlsson | 5f2bb62 | 2018-05-14 09:48:06 +0200 | [diff] [blame] | 439 | "api/video_codecs/test:builtin_video_codec_factory_unittests", |
Mirko Bonadei | bb54720 | 2017-09-15 06:15:48 +0200 | [diff] [blame] | 440 | "p2p:libstunprober_unittests", |
| 441 | "p2p:rtc_p2p_unittests", |
| 442 | "rtc_base:rtc_base_approved_unittests", |
| 443 | "rtc_base:rtc_base_tests_main", |
| 444 | "rtc_base:rtc_base_tests_utils", |
| 445 | "rtc_base:rtc_base_unittests", |
| 446 | "rtc_base:rtc_numerics_unittests", |
| 447 | "rtc_base:rtc_task_queue_unittests", |
| 448 | "rtc_base:sequenced_task_checker_unittests", |
| 449 | "rtc_base:weak_ptr_unittests", |
Sebastian Jansson | 2808ae9 | 2018-04-09 11:13:04 +0200 | [diff] [blame] | 450 | "rtc_base/experiments:experiments_unittests", |
Mirko Bonadei | bb54720 | 2017-09-15 06:15:48 +0200 | [diff] [blame] | 451 | "system_wrappers:metrics_default", |
Ilya Nikolaevskiy | 2ffe3e8 | 2018-01-17 19:57:24 +0000 | [diff] [blame] | 452 | "system_wrappers:runtime_enabled_features_default", |
Mirko Bonadei | bb54720 | 2017-09-15 06:15:48 +0200 | [diff] [blame] | 453 | ] |
| 454 | |
| 455 | if (rtc_enable_protobuf) { |
| 456 | deps += [ "logging:rtc_event_log_tests" ] |
| 457 | } |
| 458 | |
| 459 | if (is_android) { |
Sami Kalliomäki | 78498cf | 2018-02-07 16:59:33 +0100 | [diff] [blame] | 460 | # Do not use Chromium's launcher. native_unittests defines its own JNI_OnLoad. |
| 461 | use_default_launcher = false |
| 462 | |
| 463 | deps += [ |
| 464 | "sdk/android:native_unittests", |
| 465 | "sdk/android:native_unittests_java", |
| 466 | "//testing/android/native_test:native_test_support", |
| 467 | ] |
Mirko Bonadei | bb54720 | 2017-09-15 06:15:48 +0200 | [diff] [blame] | 468 | shard_timeout = 900 |
| 469 | } |
| 470 | |
| 471 | if (is_ios || is_mac) { |
| 472 | deps += [ "sdk:sdk_unittests_objc" ] |
| 473 | } |
| 474 | } |
| 475 | |
| 476 | # TODO(pbos): Rename test suite, this is no longer "just" for video targets. |
| 477 | video_engine_tests_resources = [ |
Mirko Bonadei | 92ea95e | 2017-09-15 06:47:31 +0200 | [diff] [blame] | 478 | "resources/foreman_cif_short.yuv", |
| 479 | "resources/voice_engine/audio_long16.pcm", |
Mirko Bonadei | bb54720 | 2017-09-15 06:15:48 +0200 | [diff] [blame] | 480 | ] |
| 481 | |
| 482 | if (is_ios) { |
| 483 | bundle_data("video_engine_tests_bundle_data") { |
| 484 | testonly = true |
| 485 | sources = video_engine_tests_resources |
| 486 | outputs = [ |
| 487 | "{{bundle_resources_dir}}/{{source_file_part}}", |
| 488 | ] |
| 489 | } |
| 490 | } |
| 491 | |
| 492 | rtc_test("video_engine_tests") { |
| 493 | testonly = true |
| 494 | deps = [ |
| 495 | "audio:audio_tests", |
| 496 | |
| 497 | # TODO(eladalon): call_tests aren't actually video-specific, so we |
| 498 | # should move them to a more appropriate test suite. |
| 499 | "call:call_tests", |
| 500 | "modules/video_capture", |
| 501 | "rtc_base:rtc_base_tests_utils", |
| 502 | "test:test_common", |
| 503 | "test:test_main", |
| 504 | "test:video_test_common", |
| 505 | "video:video_tests", |
| 506 | ] |
| 507 | data = video_engine_tests_resources |
| 508 | if (!build_with_chromium && is_clang) { |
| 509 | # Suppress warnings from the Chromium Clang plugin (bugs.webrtc.org/163). |
| 510 | suppressed_configs += [ "//build/config/clang:find_bad_constructs" ] |
| 511 | } |
| 512 | if (is_android) { |
| 513 | deps += [ "//testing/android/native_test:native_test_native_code" ] |
| 514 | shard_timeout = 900 |
| 515 | } |
| 516 | if (is_ios) { |
| 517 | deps += [ ":video_engine_tests_bundle_data" ] |
| 518 | } |
| 519 | } |
| 520 | |
| 521 | webrtc_perf_tests_resources = [ |
Mirko Bonadei | 92ea95e | 2017-09-15 06:47:31 +0200 | [diff] [blame] | 522 | "resources/audio_coding/speech_mono_16kHz.pcm", |
| 523 | "resources/audio_coding/speech_mono_32_48kHz.pcm", |
| 524 | "resources/audio_coding/testfile32kHz.pcm", |
| 525 | "resources/ConferenceMotion_1280_720_50.yuv", |
| 526 | "resources/difficult_photo_1850_1110.yuv", |
| 527 | "resources/foreman_cif.yuv", |
| 528 | "resources/google-wifi-3mbps.rx", |
| 529 | "resources/paris_qcif.yuv", |
| 530 | "resources/photo_1850_1110.yuv", |
| 531 | "resources/presentation_1850_1110.yuv", |
| 532 | "resources/verizon4g-downlink.rx", |
| 533 | "resources/voice_engine/audio_long16.pcm", |
| 534 | "resources/web_screenshot_1850_1110.yuv", |
Mirko Bonadei | bb54720 | 2017-09-15 06:15:48 +0200 | [diff] [blame] | 535 | ] |
| 536 | |
| 537 | if (is_ios) { |
| 538 | bundle_data("webrtc_perf_tests_bundle_data") { |
| 539 | testonly = true |
| 540 | sources = webrtc_perf_tests_resources |
| 541 | outputs = [ |
| 542 | "{{bundle_resources_dir}}/{{source_file_part}}", |
| 543 | ] |
| 544 | } |
| 545 | } |
| 546 | |
| 547 | rtc_test("webrtc_perf_tests") { |
| 548 | testonly = true |
| 549 | configs += [ ":rtc_unittests_config" ] |
| 550 | |
| 551 | deps = [ |
| 552 | "audio:audio_perf_tests", |
| 553 | "call:call_perf_tests", |
| 554 | "modules/audio_coding:audio_coding_perf_tests", |
| 555 | "modules/audio_processing:audio_processing_perf_tests", |
| 556 | "modules/remote_bitrate_estimator:remote_bitrate_estimator_perf_tests", |
| 557 | "test:test_main", |
| 558 | "video:video_full_stack_tests", |
| 559 | ] |
| 560 | |
| 561 | data = webrtc_perf_tests_resources |
| 562 | if (is_android) { |
Rasmus Brandt | 3102734 | 2017-09-29 13:48:12 +0000 | [diff] [blame] | 563 | deps += [ "//testing/android/native_test:native_test_native_code" ] |
Mirko Bonadei | bb54720 | 2017-09-15 06:15:48 +0200 | [diff] [blame] | 564 | shard_timeout = 2700 |
| 565 | } |
| 566 | if (is_ios) { |
| 567 | deps += [ ":webrtc_perf_tests_bundle_data" ] |
| 568 | } |
| 569 | } |
| 570 | |
| 571 | rtc_test("webrtc_nonparallel_tests") { |
| 572 | testonly = true |
| 573 | deps = [ |
| 574 | "rtc_base:rtc_base_nonparallel_tests", |
| 575 | ] |
| 576 | if (is_android) { |
| 577 | deps += [ "//testing/android/native_test:native_test_support" ] |
| 578 | shard_timeout = 900 |
| 579 | } |
| 580 | } |
| 581 | |
| 582 | if (is_android) { |
| 583 | junit_binary("android_junit_tests") { |
| 584 | java_files = [ |
| 585 | "examples/androidjunit/src/org/appspot/apprtc/BluetoothManagerTest.java", |
| 586 | "examples/androidjunit/src/org/appspot/apprtc/DirectRTCClientTest.java", |
| 587 | "examples/androidjunit/src/org/appspot/apprtc/TCPChannelClientTest.java", |
| 588 | "sdk/android/tests/src/org/webrtc/CameraEnumerationTest.java", |
Sami Kalliomäki | 8619e8a | 2018-04-17 14:44:36 +0200 | [diff] [blame] | 589 | "sdk/android/tests/src/org/webrtc/ScalingSettingsTest.java", |
Mirko Bonadei | bb54720 | 2017-09-15 06:15:48 +0200 | [diff] [blame] | 590 | ] |
| 591 | |
| 592 | deps = [ |
| 593 | "examples:AppRTCMobile_javalib", |
| 594 | "sdk/android:libjingle_peerconnection_java", |
| 595 | "//base:base_java_test_support", |
| 596 | ] |
| 597 | } |
ehmaldonado | 37d7a22 | 2016-11-08 06:34:20 -0800 | [diff] [blame] | 598 | } |
wjia@webrtc.org | 03cfde2 | 2014-01-14 17:48:34 +0000 | [diff] [blame] | 599 | } |
Karl Wiberg | bb23c83 | 2018-04-22 19:55:00 +0200 | [diff] [blame] | 600 | |
| 601 | # ---- Poisons ---- |
| 602 | # |
| 603 | # Here is one empty dummy target for each poison type (needed because |
| 604 | # "being poisonous with poison type foo" is implemented as "depends on |
| 605 | # //:poison_foo"). |
| 606 | # |
| 607 | # The set of poison_* targets needs to be kept in sync with the |
| 608 | # `all_poison_types` list in webrtc.gni. |
| 609 | # |
| 610 | group("poison_audio_codecs") { |
| 611 | } |
Anders Carlsson | 1f433e4 | 2018-04-24 16:39:05 +0200 | [diff] [blame] | 612 | |
| 613 | group("poison_software_video_codecs") { |
| 614 | } |