xref: /aosp_15_r20/external/pigweed/pw_fuzzer/fuzz_test.gni (revision 61c4878ac05f98d0ceed94b57d316916de578985)
1# Copyright 2020 The Pigweed Authors
2#
3# Licensed under the Apache License, Version 2.0 (the "License"); you may not
4# use this file except in compliance with the License. You may obtain a copy of
5# the License at
6#
7#     https://www.apache.org/licenses/LICENSE-2.0
8#
9# Unless required by applicable law or agreed to in writing, software
10# distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
11# WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the
12# License for the specific language governing permissions and limitations under
13# the License.
14
15import("//build_overrides/pigweed.gni")
16
17import("$dir_pw_unit_test/test.gni")
18
19# Creates a unit test that may also include fuzzing test cases.
20#
21# This template merely updates test metadata and adds a dependency on FuzzTest
22# before forwarding to `pw_test`. The resulting test can always be run as a unit
23# test. If `dir_pw_third_party_fuzztest` is set and the toolchain used to build
24# the test supports fuzzing, it can also be run as a fuzzer.
25#
26# As with `pw_test`, targets defined using this template will produce test
27# metadata with a `test_type` of "unit_test" and an additional `test_directory`
28# value describing the location of the test binary within the build output.
29# These tests can be distinguished from other unit tests by additionally having
30# a "fuzztest" tag.
31#
32# Args:
33#   - All of the `pw_test` args are accepted.
34template("pw_fuzz_test") {
35  pw_test(target_name) {
36    deps = []
37    tags = []
38    forward_variables_from(invoker, "*")
39    deps += [ "$dir_pw_fuzzer:fuzztest" ]
40    tags += [ "fuzztest" ]
41  }
42}
43