1 # Copyright 2014 The Chromium Authors. All rights reserved.
2 # Use of this source code is governed by a BSD-style license that can be
3 # found in the LICENSE file.
5 import("//build/config/features.gni")
6 import("//testing/test.gni")
9 compile_suid_client = is_linux
11 compile_credentials = is_linux
13 # On Android, use plain GTest.
14 use_base_test_suite = is_linux
17 # We have two principal targets: sandbox and sandbox_linux_unittests
18 # All other targets are listed as dependencies.
19 # There is one notable exception: for historical reasons, chrome_sandbox is
20 # the setuid sandbox and is its own target.
27 if (compile_suid_client) {
28 deps += [ ":suid_sandbox_client" ]
30 if (use_seccomp_bpf) {
33 ":seccomp_bpf_helpers",
38 source_set("sandbox_linux_test_utils") {
41 "tests/sandbox_test_runner.cc",
42 "tests/sandbox_test_runner.h",
43 "tests/sandbox_test_runner_function_pointer.cc",
44 "tests/sandbox_test_runner_function_pointer.h",
45 "tests/test_utils.cc",
47 "tests/unit_tests.cc",
55 if (use_seccomp_bpf) {
57 "seccomp-bpf/bpf_tester_compatibility_delegate.h",
58 "seccomp-bpf/bpf_tests.h",
59 "seccomp-bpf/sandbox_bpf_test_runner.cc",
60 "seccomp-bpf/sandbox_bpf_test_runner.h",
62 deps += [ ":seccomp_bpf" ]
65 if (use_base_test_suite) {
66 deps += [ "//base/test:test_support" ]
67 defines = [ "SANDBOX_USES_BASE_TEST_SUITE" ]
71 # Sources shared by sandbox_linux_unittests and sandbox_linux_jni_unittests.
72 source_set("sandbox_linux_unittests_sources") {
76 "services/proc_util_unittest.cc",
77 "services/resource_limits_unittests.cc",
78 "services/scoped_process_unittest.cc",
79 "services/syscall_wrappers_unittest.cc",
80 "services/thread_helpers_unittests.cc",
81 "services/yama_unittests.cc",
82 "syscall_broker/broker_file_permission_unittest.cc",
83 "syscall_broker/broker_process_unittest.cc",
85 "tests/scoped_temporary_file.cc",
86 "tests/scoped_temporary_file.h",
87 "tests/scoped_temporary_file_unittest.cc",
88 "tests/test_utils_unittest.cc",
89 "tests/unit_tests_unittest.cc",
94 ":sandbox_linux_test_utils",
99 if (use_base_test_suite) {
100 deps += [ "//base/test:test_support" ]
101 defines = [ "SANDBOX_USES_BASE_TEST_SUITE" ]
105 # Don't use this on Android.
109 if (compile_suid_client) {
111 "suid/client/setuid_sandbox_client_unittest.cc",
112 "suid/client/setuid_sandbox_host_unittest.cc",
115 if (use_seccomp_bpf) {
117 "bpf_dsl/bpf_dsl_unittest.cc",
118 "bpf_dsl/codegen_unittest.cc",
119 "bpf_dsl/cons_unittest.cc",
120 "bpf_dsl/dump_bpf.cc",
121 "bpf_dsl/dump_bpf.h",
122 "bpf_dsl/errorcode_unittest.cc",
123 "bpf_dsl/syscall_set_unittest.cc",
124 "bpf_dsl/test_trap_registry.cc",
125 "bpf_dsl/test_trap_registry.h",
126 "bpf_dsl/test_trap_registry_unittest.cc",
127 "bpf_dsl/verifier.cc",
128 "bpf_dsl/verifier.h",
129 "integration_tests/bpf_dsl_seccomp_unittest.cc",
130 "integration_tests/seccomp_broker_process_unittest.cc",
131 "seccomp-bpf-helpers/baseline_policy_unittest.cc",
132 "seccomp-bpf-helpers/syscall_parameters_restrictions_unittests.cc",
133 "seccomp-bpf/bpf_tests_unittest.cc",
134 "seccomp-bpf/sandbox_bpf_unittest.cc",
135 "seccomp-bpf/syscall_unittest.cc",
136 "seccomp-bpf/trap_unittest.cc",
138 deps += [ ":bpf_dsl_golden" ]
140 if (compile_credentials) {
142 "integration_tests/namespace_unix_domain_socket_unittest.cc",
143 "services/credentials_unittest.cc",
144 "services/namespace_utils_unittest.cc",
147 if (use_base_test_suite) {
148 # Tests that use advanced features not available in stock GTest.
149 sources += [ "services/namespace_sandbox_unittest.cc" ]
152 # For credentials_unittest.cc
153 configs += [ "//build/config/linux:libcap" ]
157 action("bpf_dsl_golden") {
158 script = "bpf_dsl/golden/generate.py"
160 "bpf_dsl/golden/i386/ArgSizePolicy.txt",
161 "bpf_dsl/golden/i386/BasicPolicy.txt",
162 "bpf_dsl/golden/i386/ElseIfPolicy.txt",
163 "bpf_dsl/golden/i386/MaskingPolicy.txt",
164 "bpf_dsl/golden/i386/MoreBooleanLogicPolicy.txt",
165 "bpf_dsl/golden/i386/NegativeConstantsPolicy.txt",
166 "bpf_dsl/golden/i386/SwitchPolicy.txt",
167 "bpf_dsl/golden/x86-64/ArgSizePolicy.txt",
168 "bpf_dsl/golden/x86-64/BasicPolicy.txt",
169 "bpf_dsl/golden/x86-64/BooleanLogicPolicy.txt",
170 "bpf_dsl/golden/x86-64/ElseIfPolicy.txt",
171 "bpf_dsl/golden/x86-64/MaskingPolicy.txt",
172 "bpf_dsl/golden/x86-64/MoreBooleanLogicPolicy.txt",
173 "bpf_dsl/golden/x86-64/NegativeConstantsPolicy.txt",
174 "bpf_dsl/golden/x86-64/SwitchPolicy.txt",
177 "$target_gen_dir/bpf_dsl/golden/golden_files.h",
180 rebase_path(outputs, root_build_dir) + rebase_path(inputs, root_build_dir)
183 # TODO(GYP): Delete this after we've converted everything to GN.
184 # The _run targets exist only for compatibility w/ GYP.
185 group("sandbox_linux_unittests_run") {
188 ":sandbox_linux_unittests",
192 # The main sandboxing test target.
193 test("sandbox_linux_unittests") {
195 ":sandbox_linux_unittests_sources",
199 # This target is the shared library used by Android APK (i.e.
200 # JNI-friendly) tests.
201 shared_library("sandbox_linux_jni_unittests") {
204 ":sandbox_linux_unittests_sources",
205 "//build/config/sanitizers:deps",
208 deps += [ "//testing/android/native_test:native_test_native_code" ]
212 component("seccomp_bpf") {
214 "bpf_dsl/bpf_dsl.cc",
216 "bpf_dsl/bpf_dsl_forward.h",
217 "bpf_dsl/bpf_dsl_impl.h",
218 "bpf_dsl/codegen.cc",
221 "bpf_dsl/errorcode.cc",
222 "bpf_dsl/errorcode.h",
223 "bpf_dsl/linux_syscall_ranges.h",
226 "bpf_dsl/policy_compiler.cc",
227 "bpf_dsl/policy_compiler.h",
228 "bpf_dsl/seccomp_macros.h",
229 "bpf_dsl/syscall_set.cc",
230 "bpf_dsl/syscall_set.h",
231 "bpf_dsl/trap_registry.h",
232 "seccomp-bpf/die.cc",
234 "seccomp-bpf/sandbox_bpf.cc",
235 "seccomp-bpf/sandbox_bpf.h",
236 "seccomp-bpf/syscall.cc",
237 "seccomp-bpf/syscall.h",
238 "seccomp-bpf/trap.cc",
239 "seccomp-bpf/trap.h",
241 defines = [ "SANDBOX_IMPLEMENTATION" ]
245 ":sandbox_services_headers",
250 component("seccomp_bpf_helpers") {
252 "seccomp-bpf-helpers/baseline_policy.cc",
253 "seccomp-bpf-helpers/baseline_policy.h",
254 "seccomp-bpf-helpers/sigsys_handlers.cc",
255 "seccomp-bpf-helpers/sigsys_handlers.h",
256 "seccomp-bpf-helpers/syscall_parameters_restrictions.cc",
257 "seccomp-bpf-helpers/syscall_parameters_restrictions.h",
258 "seccomp-bpf-helpers/syscall_sets.cc",
259 "seccomp-bpf-helpers/syscall_sets.h",
261 defines = [ "SANDBOX_IMPLEMENTATION" ]
271 # The setuid sandbox for Linux.
272 executable("chrome_sandbox") {
274 "suid/common/sandbox.h",
275 "suid/common/suid_unsafe_environment_variables.h",
276 "suid/process_util.h",
277 "suid/process_util_linux.c",
285 # These files have a suspicious comparison.
286 # TODO fix this and re-enable this warning.
291 "//build/config/sanitizers:deps",
296 component("sandbox_services") {
298 "services/init_process_reaper.cc",
299 "services/init_process_reaper.h",
300 "services/proc_util.cc",
301 "services/proc_util.h",
302 "services/resource_limits.cc",
303 "services/resource_limits.h",
304 "services/scoped_process.cc",
305 "services/scoped_process.h",
306 "services/syscall_wrappers.cc",
307 "services/syscall_wrappers.h",
308 "services/thread_helpers.cc",
309 "services/thread_helpers.h",
312 "syscall_broker/broker_channel.cc",
313 "syscall_broker/broker_channel.h",
314 "syscall_broker/broker_client.cc",
315 "syscall_broker/broker_client.h",
316 "syscall_broker/broker_common.h",
317 "syscall_broker/broker_file_permission.cc",
318 "syscall_broker/broker_file_permission.h",
319 "syscall_broker/broker_host.cc",
320 "syscall_broker/broker_host.h",
321 "syscall_broker/broker_policy.cc",
322 "syscall_broker/broker_policy.h",
323 "syscall_broker/broker_process.cc",
324 "syscall_broker/broker_process.h",
327 defines = [ "SANDBOX_IMPLEMENTATION" ]
333 if (compile_credentials) {
335 "services/credentials.cc",
336 "services/credentials.h",
337 "services/namespace_sandbox.cc",
338 "services/namespace_sandbox.h",
339 "services/namespace_utils.cc",
340 "services/namespace_utils.h",
343 deps += [ ":sandbox_services_headers" ]
347 source_set("sandbox_services_headers") {
349 "system_headers/arm64_linux_syscalls.h",
350 "system_headers/arm64_linux_ucontext.h",
351 "system_headers/arm_linux_syscalls.h",
352 "system_headers/arm_linux_ucontext.h",
353 "system_headers/i386_linux_ucontext.h",
354 "system_headers/linux_futex.h",
355 "system_headers/linux_seccomp.h",
356 "system_headers/linux_signal.h",
357 "system_headers/linux_syscalls.h",
358 "system_headers/linux_time.h",
359 "system_headers/linux_ucontext.h",
360 "system_headers/x86_32_linux_syscalls.h",
361 "system_headers/x86_64_linux_syscalls.h",
365 # We make this its own target so that it does not interfere with our tests.
366 source_set("libc_urandom_override") {
368 "services/libc_urandom_override.cc",
369 "services/libc_urandom_override.h",
376 if (compile_suid_client) {
377 component("suid_sandbox_client") {
379 "suid/client/setuid_sandbox_client.cc",
380 "suid/client/setuid_sandbox_client.h",
381 "suid/client/setuid_sandbox_host.cc",
382 "suid/client/setuid_sandbox_host.h",
383 "suid/common/sandbox.h",
384 "suid/common/suid_unsafe_environment_variables.h",
386 defines = [ "SANDBOX_IMPLEMENTATION" ]
396 # TODO(GYP) enable this. Needs an android_strip wrapper python script.
397 #action("sandbox_linux_unittests_stripped") {
398 # script = "android_stip.py"
400 # in_file = "$root_out_dir/sandbox_linux_unittests"
402 # out_file = "$root_out_dir/sandbox_linux_unittests_stripped"
403 # outputs = [ out_file ]
406 # rebase_path(in_file, root_build_dir),
407 # "-o", rebase_path(out_file, root_build_dir),
411 # ":sandbox_linux_unittests",
414 # TODO(GYP) convert this.
416 # 'target_name': 'sandbox_linux_jni_unittests_apk',
419 # 'test_suite_name': 'sandbox_linux_jni_unittests',
422 # 'sandbox_linux_jni_unittests',
424 # 'includes': [ '../../build/apk_test.gypi' ],