Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(789)

Side by Side Diff: sandbox/linux/seccomp-bpf/bpf_tests.h

Issue 10878033: Simplified unit testing of sandboxing code. (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: Addressed reviewer's comments Created 8 years, 4 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View unified diff | Download patch | Annotate | Revision Log
OLDNEW
(Empty)
1 // Copyright (c) 2012 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.
4
5 #ifndef SANDBOX_LINUX_SECCOMP_BPF_BPF_TESTS_H__
6 #define SANDBOX_LINUX_SECCOMP_BPF_BPF_TESTS_H__
7
8 #include "sandbox/linux/tests/unit_tests.h"
9 #include "sandbox/linux/seccomp-bpf/sandbox_bpf.h"
10
11
12 namespace sandbox {
13
14 // BPF_TEST() is a special version of SANDBOX_TEST(). It turns into a no-op,
15 // if the host does not have kernel support for running BPF filters.
16 // Also, it takes advantage of the Die class to avoid calling LOG(FATAL), from
17 // inside our tests, as we don't need or even want all the error handling that
18 // LOG(FATAL) would do.
19 #define BPF_TEST(test_case_name, test_name, policy) \
20 void BPF_TEST_##test_name(); \
21 void BPF_TEST_##test_name##_wrapper() { \
22 Die::EnableSimpleExit(); \
23 if (reinterpret_cast<void *>(policy) != NULL) { \
24 Sandbox::setSandboxPolicy(policy, NULL); \
25 } \
26 BPF_TEST_##test_name(); \
27 } \
28 TEST(test_case_name, test_name) { \
29 if (playground2::Sandbox::supportsSeccompSandbox(-1) == \
30 Sandbox::STATUS_AVAILABLE) { \
31 sandbox::BpfTests::RunTestInProcess(BPF_TEST_##test_name##_wrapper); \
32 } else { \
33 /* TODO(markus): Call the compiler and verify the policy. That's the */ \
jln (very slow on Chromium) 2012/08/24 04:00:32 I'm sorry I wasn't clear: I meant to call setSandb
34 /* least we can do, if we don't have kernel support. */ \
35 } \
36 } \
37 void BPF_TEST_##test_name()
38
39 // Assertions are handled exactly the same as with a normal SANDBOX_TEST()
40 #define BPF_ASSERT SANDBOX_ASSERT
41
42
43 class BpfTests : public UnitTests {
44 private:
45 DISALLOW_IMPLICIT_CONSTRUCTORS(BpfTests);
46 };
47
48 } // namespace
49
50 #endif // SANDBOX_LINUX_SECCOMP_BPF_BPF_TESTS_H__
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698