1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
|
load("@rules_cc//cc:defs.bzl", "cc_binary", "cc_library", "cc_test")
load("//bazel:cc.bzl", "cc_17_library")
cc_library(
name = "sanitizer_hooks_with_pc",
srcs = ["sanitizer_hooks_with_pc.cpp"],
hdrs = ["sanitizer_hooks_with_pc.h"],
)
cc_test(
name = "sanitizer_hooks_with_pc_test",
size = "small",
srcs = ["sanitizer_hooks_with_pc_test.cpp"],
deps = [
":sanitizer_hooks_with_pc",
"@googletest//:gtest",
"@googletest//:gtest_main",
],
)
cc_library(
name = "jvm_tooling_lib",
srcs = [
"coverage_tracker.cpp",
"fuzz_target_runner.cpp",
"fuzzed_data_provider.cpp",
"java_reproducer_templates.h",
"jvm_tooling.cpp",
"libfuzzer_callbacks.cpp",
"libfuzzer_callbacks.h",
"libfuzzer_driver.cpp",
"signal_handler.cpp",
"signal_handler.h",
"utils.cpp",
"utils.h",
],
hdrs = [
"coverage_tracker.h",
"fuzz_target_runner.h",
"fuzzed_data_provider.h",
"jvm_tooling.h",
"libfuzzer_driver.h",
],
linkopts = [
"-ldl",
],
visibility = ["//visibility:public"],
deps = [
":sanitizer_hooks_with_pc",
"//third_party/jni:jni_libs",
"@bazel_tools//tools/cpp/runfiles",
"@bazel_tools//tools/jdk:jni",
"@com_google_absl//absl/strings",
"@com_google_absl//absl/strings:str_format",
"@com_google_glog//:glog",
"@jazzer_com_github_gflags_gflags//:gflags",
],
)
cc_17_library(
name = "driver_lib",
srcs = [
"libfuzzer_fuzz_target.cpp",
],
deps = [
":jvm_tooling_lib",
"@jazzer_libfuzzer//:libFuzzer",
],
alwayslink = True,
)
cc_binary(
name = "jazzer_driver",
data = [
"//agent:jazzer_agent_deploy.jar",
],
linkopts = [
"-rdynamic",
],
visibility = ["//visibility:public"],
deps = [":driver_lib"],
)
cc_binary(
name = "jazzer_driver_asan",
data = [
"//agent:jazzer_agent_deploy.jar",
],
linkopts = [
"-fsanitize=address",
"-rdynamic",
],
visibility = ["//visibility:public"],
deps = [":driver_lib"],
)
cc_binary(
name = "jazzer_driver_ubsan",
data = [
"//agent:jazzer_agent_deploy.jar",
],
linkopts = [
"-fsanitize=undefined",
"-rdynamic",
],
visibility = ["//visibility:public"],
deps = [":driver_lib"],
)
cc_test(
name = "jvm_tooling_test",
size = "small",
srcs = [
"jvm_tooling_test.cpp",
"sanitizer_symbols_for_tests.cpp",
],
args = [
"--cp=$(location //driver/testdata:fuzz_target_mocks_deploy.jar)",
"--agent_path=$(rootpath //agent:jazzer_agent_deploy.jar)",
],
data = [
"//agent:jazzer_agent_deploy.jar",
"//driver/testdata:fuzz_target_mocks_deploy.jar",
],
includes = ["."],
deps = [
":jvm_tooling_lib",
":test_main",
"@googletest//:gtest",
"@jazzer_com_github_gflags_gflags//:gflags",
],
)
cc_test(
name = "fuzzed_data_provider_test",
size = "medium",
srcs = [
"fuzzed_data_provider_test.cpp",
"sanitizer_symbols_for_tests.cpp",
],
args = [
"--cp=$(location //driver/testdata:fuzz_target_mocks_deploy.jar)",
"--agent_path=$(rootpath //agent:jazzer_agent_deploy.jar)",
],
data = [
"//agent:jazzer_agent_deploy.jar",
"//driver/testdata:fuzz_target_mocks_deploy.jar",
],
includes = ["."],
deps = [
":jvm_tooling_lib",
":test_main",
"@googletest//:gtest",
"@jazzer_com_github_gflags_gflags//:gflags",
],
)
cc_library(
name = "test_main",
srcs = ["test_main.cpp"],
deps = [
"@googletest//:gtest",
"@jazzer_com_github_gflags_gflags//:gflags",
],
)
|