Fuzz introspector
For issues and ideas: https://github.com/ossf/fuzz-introspector/issues

Project functions overview

The following table shows data about each function in the project. The functions included in this table correspond to all functions that exist in the executables of the fuzzers. As such, there may be functions that are from third-party libraries.

For further technical details on the meaning of columns in the below table, please see the Glossary .

Func name Functions filename Args Function call depth Reached by Fuzzers Runtime reached by Fuzzers Combined reached by Fuzzers Fuzzers runtime hit Func lines hit % I Count BB Count Cyclomatic complexity Functions reached Reached by functions Accumulated cyclomatic complexity Undiscovered complexity

Fuzzer details

Fuzzer: fuzzfuzz_http

Call tree

The calltree shows the control flow of the fuzzer. This is overlaid with coverage information to display how much of the potential code a fuzzer can reach is in fact covered at runtime. In the following there is a link to a detailed calltree visualisation as well as a bitmap showing a high-level view of the calltree. For further information about these topics please see the glossary for full calltree and calltree overview

Call tree overview bitmap:

The distribution of callsites in terms of coloring is
Color Runtime hitcount Callsite count Percentage
red 0 1905 98.5%
gold [1:9] 5 0.25%
yellow [10:29] 5 0.25%
greenyellow [30:49] 0 0.0%
lawngreen 50+ 19 0.98%
All colors 1934 100

Fuzz blockers

The following nodes represent call sites where fuzz blockers occur.

Amount of callsites blocked Calltree index Parent function Callsite Largest blocked function
592 575 PathAndQuery::empty call site: 00575 single_stream_send_extra_large_body_multi_frames_one_buffer
547 1208 Prioritize::new call site: 01208 recv_invalid_push_promise_headers_is_stream_protocol_error
436 123 std::str::from_utf8 call site: 00123 recv_invalid_push_promise_headers_is_stream_protocol_error
149 1759 Table::new call site: 01759 rst_stream_max
95 24 Table::new call site: 00024 single_stream_send_extra_large_body_multi_frames_one_buffer
37 1169 Recv::new call site: 01169 FlowControl::inc_window
15 2 Request::builder call site: 00002 Codec::with_max_recv_frame_size
11 560 Pos::is_some call site: 00560 if_downcast_into
10 1922 StatusCode::from_bytes call site: 01922 Frame::map
5 18 FramedWrite::new call site: 00018 Encoder::new
3 1909 StatusCode::from_bytes call site: 01909 HeaderName::as_ref
2 1756 Table::new call site: 01756

Runtime coverage analysis

Covered functions
179
Functions that are reachable but not covered
23
Reachable functions
34
Percentage of reachable functions covered
32.35%
NB: The sum of covered functions and functions that are reachable but not covered need not be equal to Reachable functions . This is because the reachability analysis is an approximation and thus at runtime some functions may be covered that are not included in the reachability analysis. This is a limitation of our static analysis capabilities.
Warning: The number of covered functions are larger than the number of reachable functions. This means that there are more functions covered at runtime than are extracted using static analysis. This is likely a result of the static analysis component failing to extract the right call graph or the coverage runtime being compiled with sanitizers in code that the static analysis has not analysed. This can happen if lto/gold is not used in all places that coverage instrumentation is used.
Function name source code lines source lines hit percentage hit

Files reached

filename functions hit
http/fuzzfuzz_http.rs 7
httprequest.rs 13
h2/tests/h2-supportmock.rs 91
h2/tests/h2-tests/tests/server.rs 61
h2client.rs 13
h2codec/mod.rs 13
h2/tests/h2-tests/tests/stream_states.rs 71
httpconvert.rs 6
h2/tests/h2-tests/tests/prioritization.rs 25
h2server.rs 19
h2codec/framed_read.rs 7
h2proto/error.rs 2
h2/tests/h2-supportassert.rs 5
h2/tests/h2-supportutil.rs 14
h2ext.rs 7
httpbyte_str.rs 2
httpheader/value.rs 1
h2/tests/h2-tests/tests/flow_control.rs 49
h2frame/mod.rs 3
h2/tests/h2-supportframes.rs 21
h2/tests/h2-tests/tests/codec_read.rs 3
h2/tests/h2-supportraw.rs 4
h2/tests/h2-tests/tests/push_promise.rs 38
h2hpack/decoder.rs 8
h2proto/streams/store.rs 6
h2frame/headers.rs 7
httpheader/map.rs 15
h2hpack/header.rs 2
h2/tests/h2-supportfuture_ext.rs 13
h2lib.rs 1
h2proto/streams/streams.rs 6
h2/tests/h2-fuzzmain.rs 31
h2/tests/h2-tests/tests/client_request.rs 25
httpuri/builder.rs 2
h2share.rs 10
h2proto/connection.rs 9
h2proto/settings.rs 3
h2/tests/h2-supportclient_ext.rs 7
h2hpack/encoder.rs 1
h2proto/streams/prioritize.rs 2
h2frame/settings.rs 2
h2proto/streams/flow_control.rs 11
h2proto/streams/recv.rs 10
h2/tests/h2-tests/tests/ping_pong.rs 31
h2proto/ping_pong.rs 8
h2hpack/table.rs 2
http/tests/status_code.rs 7

Fuzzer: fuzz_hpack

Call tree

The calltree shows the control flow of the fuzzer. This is overlaid with coverage information to display how much of the potential code a fuzzer can reach is in fact covered at runtime. In the following there is a link to a detailed calltree visualisation as well as a bitmap showing a high-level view of the calltree. For further information about these topics please see the glossary for full calltree and calltree overview

Call tree overview bitmap:

The distribution of callsites in terms of coloring is
Color Runtime hitcount Callsite count Percentage
red 0 2016 89.3%
gold [1:9] 2 0.08%
yellow [10:29] 6 0.26%
greenyellow [30:49] 0 0.0%
lawngreen 50+ 233 10.3%
All colors 2257 100

Fuzz blockers

The following nodes represent call sites where fuzz blockers occur.

Amount of callsites blocked Calltree index Parent function Callsite Largest blocked function
696 1198 proto::Connection::new call site: 01198 rst_stream_max
620 269 HeaderName::as_str call site: 00269 recv_invalid_push_promise_headers_is_stream_protocol_error
300 897 take call site: 00897 single_stream_send_extra_large_body_multi_frames_one_buffer
180 83 h2::frame::BytesStr::try_from call site: 00083 srv_window_update_on_lower_stream_id
56 18 Encoder::new call site: 00018 single_stream_send_extra_large_body_multi_frames_one_buffer
14 3 h2::fuzz_bridge::fuzz_logic::fuzz_hpack call site: 00003 Codec::with_max_recv_frame_size
13 1915 Decoder::decode_indexed call site: 01915
13 2185 Name::into_entry call site: 02185 Decoder::decode_literal
12 1953 Decoder::try_decode_string call site: 01953 Frame::map
10 2053 StatusCode::from_bytes call site: 02053 Frame::map
9 2086 parse_hdr call site: 02086 Store::try_for_each
9 2202 Table::set_max_size call site: 02202 Deque::push_back

Runtime coverage analysis

Covered functions
210
Functions that are reachable but not covered
1
Reachable functions
2
Percentage of reachable functions covered
50.0%
NB: The sum of covered functions and functions that are reachable but not covered need not be equal to Reachable functions . This is because the reachability analysis is an approximation and thus at runtime some functions may be covered that are not included in the reachability analysis. This is a limitation of our static analysis capabilities.
Warning: The number of covered functions are larger than the number of reachable functions. This means that there are more functions covered at runtime than are extracted using static analysis. This is likely a result of the static analysis component failing to extract the right call graph or the coverage runtime being compiled with sanitizers in code that the static analysis has not analysed. This can happen if lto/gold is not used in all places that coverage instrumentation is used.
Function name source code lines source lines hit percentage hit

Files reached

filename functions hit
h2/fuzz/fuzz_targets/fuzz_hpack.rs 2
h2fuzz_bridge.rs 11
h2/tests/h2-supportmock.rs 106
h2client.rs 13
h2codec/mod.rs 13
h2/tests/h2-tests/tests/server.rs 56
h2/tests/h2-tests/tests/stream_states.rs 71
httpconvert.rs 6
h2/tests/h2-tests/tests/prioritization.rs 25
h2/tests/h2-supportassert.rs 5
h2/tests/h2-supportutil.rs 14
h2ext.rs 8
httpbyte_str.rs 2
httpheader/value.rs 6
h2/tests/h2-tests/tests/flow_control.rs 49
httprequest.rs 13
h2codec/framed_read.rs 7
h2proto/error.rs 2
h2frame/mod.rs 3
h2/tests/h2-supportframes.rs 21
h2/tests/h2-tests/tests/codec_read.rs 5
h2/tests/h2-supportraw.rs 4
h2/tests/h2-tests/tests/push_promise.rs 38
h2hpack/decoder.rs 35
h2proto/streams/store.rs 12
h2frame/headers.rs 7
httpheader/map.rs 14
h2hpack/header.rs 17
h2/tests/h2-supportfuture_ext.rs 13
h2lib.rs 1
h2proto/connection.rs 9
h2proto/settings.rs 3
h2/tests/h2-supportclient_ext.rs 7
h2proto/streams/streams.rs 6
h2server.rs 19
h2/tests/h2-fuzzmain.rs 31
h2/tests/h2-tests/tests/client_request.rs 25
httpuri/builder.rs 2
h2share.rs 10
h2hpack/encoder.rs 17
h2proto/streams/prioritize.rs 3
h2frame/settings.rs 2
h2proto/streams/flow_control.rs 11
h2proto/streams/recv.rs 10
h2/tests/h2-tests/tests/ping_pong.rs 31
h2proto/ping_pong.rs 8
h2hpack/table.rs 2
httpextensions.rs 2
http/tests/status_code.rs 14
httpmethod.rs 4
httpheader/name.rs 22
h2proto/streams/buffer.rs 2

Fuzzer: fuzz_client

Call tree

The calltree shows the control flow of the fuzzer. This is overlaid with coverage information to display how much of the potential code a fuzzer can reach is in fact covered at runtime. In the following there is a link to a detailed calltree visualisation as well as a bitmap showing a high-level view of the calltree. For further information about these topics please see the glossary for full calltree and calltree overview

Call tree overview bitmap:

The distribution of callsites in terms of coloring is
Color Runtime hitcount Callsite count Percentage
red 0 1821 95.1%
gold [1:9] 5 0.26%
yellow [10:29] 0 0.0%
greenyellow [30:49] 0 0.0%
lawngreen 50+ 88 4.59%
All colors 1914 100

Fuzz blockers

The following nodes represent call sites where fuzz blockers occur.

Amount of callsites blocked Calltree index Parent function Callsite Largest blocked function
395 1381 frame::Headers::new call site: 01381 recv_invalid_push_promise_headers_is_stream_protocol_error
250 752 PathAndQuery::empty call site: 00752 single_stream_send_extra_large_body_multi_frames_one_buffer
172 275 calculate_headermap_size call site: 00275 recv_invalid_push_promise_headers_is_stream_protocol_error
155 90 Request::builder call site: 00090 srv_window_update_on_lower_stream_id
123 1066 C::o::n::n::e::c::t::i::o::n::::::::n::e::w::streams_config call site: 01066 srv_window_update_on_lower_stream_id
115 1264 Window::add call site: 01264 run
111 625 Codec::framed_write call site: 00625 srv_window_update_on_lower_stream_id
101 458 StreamRef::clone_to_opaque call site: 00458 recv_invalid_push_promise_headers_is_stream_protocol_error
80 1833 calc_max_continuation_frames call site: 01833 rst_stream_max
64 1197 Settings::new call site: 01197 Handle::assert_client_handshake_with_settings
61 563 SendRequest::send_request call site: 00563 srv_window_update_on_lower_stream_id
52 21 mock::new call site: 00021 single_stream_send_extra_large_body_multi_frames_one_buffer

Runtime coverage analysis

Covered functions
1364
Functions that are reachable but not covered
22
Reachable functions
35
Percentage of reachable functions covered
37.14%
NB: The sum of covered functions and functions that are reachable but not covered need not be equal to Reachable functions . This is because the reachability analysis is an approximation and thus at runtime some functions may be covered that are not included in the reachability analysis. This is a limitation of our static analysis capabilities.
Warning: The number of covered functions are larger than the number of reachable functions. This means that there are more functions covered at runtime than are extracted using static analysis. This is likely a result of the static analysis component failing to extract the right call graph or the coverage runtime being compiled with sanitizers in code that the static analysis has not analysed. This can happen if lto/gold is not used in all places that coverage instrumentation is used.
Function name source code lines source lines hit percentage hit

Files reached

filename functions hit
h2/fuzz/fuzz_targets/fuzz_client.rs 12
h2/tests/h2-supportmock.rs 91
h2client.rs 13
h2codec/mod.rs 13
h2/tests/h2-tests/tests/server.rs 61
h2/tests/h2-tests/tests/stream_states.rs 71
httpconvert.rs 6
h2/tests/h2-tests/tests/prioritization.rs 25
h2/tests/h2-supportassert.rs 5
h2/tests/h2-supportutil.rs 14
h2ext.rs 7
httpbyte_str.rs 2
httpheader/value.rs 1
h2/tests/h2-tests/tests/flow_control.rs 49
httprequest.rs 13
h2codec/framed_read.rs 7
h2proto/error.rs 2
h2frame/mod.rs 3
h2/tests/h2-supportframes.rs 21
h2/tests/h2-tests/tests/codec_read.rs 3
h2/tests/h2-supportraw.rs 4
h2/tests/h2-tests/tests/push_promise.rs 38
h2hpack/decoder.rs 8
h2proto/streams/store.rs 6
h2frame/headers.rs 7
httpheader/map.rs 15
h2hpack/header.rs 2
h2/tests/h2-supportfuture_ext.rs 13
h2lib.rs 1
h2proto/connection.rs 9
h2proto/settings.rs 3
h2/tests/h2-supportclient_ext.rs 7
h2proto/streams/streams.rs 6
h2server.rs 19
h2/tests/h2-fuzzmain.rs 31
h2/tests/h2-tests/tests/client_request.rs 25
httpuri/builder.rs 2
h2share.rs 10
h2hpack/encoder.rs 1
h2proto/streams/prioritize.rs 2
h2frame/settings.rs 2
h2proto/streams/flow_control.rs 11
h2proto/streams/recv.rs 10
h2/tests/h2-tests/tests/ping_pong.rs 31
h2proto/ping_pong.rs 8
h2hpack/table.rs 2

Fuzzer: fuzz_e2e

Call tree

The calltree shows the control flow of the fuzzer. This is overlaid with coverage information to display how much of the potential code a fuzzer can reach is in fact covered at runtime. In the following there is a link to a detailed calltree visualisation as well as a bitmap showing a high-level view of the calltree. For further information about these topics please see the glossary for full calltree and calltree overview

Call tree overview bitmap:

The distribution of callsites in terms of coloring is
Color Runtime hitcount Callsite count Percentage
red 0 1744 91.9%
gold [1:9] 3 0.15%
yellow [10:29] 8 0.42%
greenyellow [30:49] 2 0.10%
lawngreen 50+ 139 7.33%
All colors 1896 100

Fuzz blockers

The following nodes represent call sites where fuzz blockers occur.

Amount of callsites blocked Calltree index Parent function Callsite Largest blocked function
172 275 calculate_headermap_size call site: 00275 recv_invalid_push_promise_headers_is_stream_protocol_error
154 1622 Poll::map_err call site: 01622 recv_invalid_push_promise_headers_is_stream_protocol_error
129 759 Result::map_err call site: 00759 run
123 1066 C::o::n::n::e::c::t::i::o::n::::::::n::e::w::streams_config call site: 01066 srv_window_update_on_lower_stream_id
114 1503 MockIo::poll_flush call site: 01503 reset_new_stream_before_send
113 889 position call site: 00889 single_stream_send_extra_large_body_multi_frames_one_buffer
105 1274 FlowControl::unclaimed_capacity call site: 01274 run
101 458 StreamRef::clone_to_opaque call site: 00458 recv_invalid_push_promise_headers_is_stream_protocol_error
72 155 frame::Settings::ack call site: 00155 srv_window_update_on_lower_stream_id
66 1381 frame::Headers::new call site: 01381 recv_invalid_push_promise_headers_is_stream_protocol_error
64 1197 Settings::new call site: 01197 Handle::assert_client_handshake_with_settings
62 1833 calc_max_continuation_frames call site: 01833 rst_stream_max

Runtime coverage analysis

Covered functions
2127
Functions that are reachable but not covered
19
Reachable functions
48
Percentage of reachable functions covered
60.42%
NB: The sum of covered functions and functions that are reachable but not covered need not be equal to Reachable functions . This is because the reachability analysis is an approximation and thus at runtime some functions may be covered that are not included in the reachability analysis. This is a limitation of our static analysis capabilities.
Warning: The number of covered functions are larger than the number of reachable functions. This means that there are more functions covered at runtime than are extracted using static analysis. This is likely a result of the static analysis component failing to extract the right call graph or the coverage runtime being compiled with sanitizers in code that the static analysis has not analysed. This can happen if lto/gold is not used in all places that coverage instrumentation is used.
Function name source code lines source lines hit percentage hit

Files reached

filename functions hit
h2/fuzz/fuzz_targets/fuzz_e2e.rs 4
h2/tests/h2-supportmock.rs 91
h2client.rs 13
h2codec/mod.rs 13
h2/tests/h2-tests/tests/server.rs 56
h2/tests/h2-tests/tests/stream_states.rs 71
httpconvert.rs 6
h2/tests/h2-tests/tests/prioritization.rs 25
h2/tests/h2-supportassert.rs 5
h2/tests/h2-supportutil.rs 14
h2ext.rs 7
httpbyte_str.rs 2
httpheader/value.rs 1
h2/tests/h2-tests/tests/flow_control.rs 49
httprequest.rs 13
h2codec/framed_read.rs 7
h2proto/error.rs 2
h2frame/mod.rs 3
h2/tests/h2-supportframes.rs 21
h2/tests/h2-tests/tests/codec_read.rs 3
h2/tests/h2-supportraw.rs 4
h2/tests/h2-tests/tests/push_promise.rs 38
h2hpack/decoder.rs 8
h2proto/streams/store.rs 6
h2frame/headers.rs 7
httpheader/map.rs 14
h2hpack/header.rs 2
h2/tests/h2-supportfuture_ext.rs 13
h2lib.rs 1
h2proto/connection.rs 9
h2proto/settings.rs 3
h2/tests/h2-supportclient_ext.rs 7
h2proto/streams/streams.rs 6
h2server.rs 19
h2/tests/h2-fuzzmain.rs 31
h2/tests/h2-tests/tests/client_request.rs 25
httpuri/builder.rs 2
h2share.rs 10
h2hpack/encoder.rs 1
h2proto/streams/prioritize.rs 2
h2frame/settings.rs 2
h2proto/streams/flow_control.rs 11
h2proto/streams/recv.rs 10
h2/tests/h2-tests/tests/ping_pong.rs 31
h2proto/ping_pong.rs 8
h2hpack/table.rs 2

Fuzz engine guidance

This sections provides heuristics that can be used as input to a fuzz engine when running a given fuzz target. The current focus is on providing input that is usable by libFuzzer.

http/fuzzfuzz_http.rs

Dictionary

Use this with the libFuzzer -dict=DICT.file flag


Fuzzer function priority

Use one of these functions as input to libfuzzer with flag: -focus_function name

-focus_function=['PathAndQuery::empty', 'Prioritize::new', 'std::str::from_utf8', 'fuzz_target', 'Table::new', 'Recv::new', 'Request::builder', 'Pos::is_some', 'StatusCode::from_bytes', 'FramedWrite::new']

h2/fuzz/fuzz_targets/fuzz_hpack.rs

Dictionary

Use this with the libFuzzer -dict=DICT.file flag


Fuzzer function priority

Use one of these functions as input to libfuzzer with flag: -focus_function name

-focus_function=['proto::Connection::new', 'HeaderName::as_str', 'take', 'h2::frame::BytesStr::try_from', 'Encoder::new', 'h2::fuzz_bridge::fuzz_logic::fuzz_hpack', 'Decoder::decode_indexed', 'Name::into_entry', 'Decoder::try_decode_string', 'StatusCode::from_bytes']

h2/fuzz/fuzz_targets/fuzz_client.rs

Dictionary

Use this with the libFuzzer -dict=DICT.file flag


Fuzzer function priority

Use one of these functions as input to libfuzzer with flag: -focus_function name

-focus_function=['frame::Headers::new', 'PathAndQuery::empty', 'calculate_headermap_size', 'Request::builder', 'C::o::n::n::e::c::t::i::o::n::::::::n::e::w::streams_config', 'Window::add', 'Codec::framed_write', 'StreamRef::clone_to_opaque', 'calc_max_continuation_frames', 'Settings::new']

h2/fuzz/fuzz_targets/fuzz_e2e.rs

Dictionary

Use this with the libFuzzer -dict=DICT.file flag


Fuzzer function priority

Use one of these functions as input to libfuzzer with flag: -focus_function name

-focus_function=['calculate_headermap_size', 'Poll::map_err', 'Result::map_err', 'C::o::n::n::e::c::t::i::o::n::::::::n::e::w::streams_config', 'MockIo::poll_flush', 'position', 'FlowControl::unclaimed_capacity', 'StreamRef::clone_to_opaque', 'frame::Settings::ack', 'frame::Headers::new']

Runtime coverage analysis

This section shows analysis of runtime coverage data.

For futher technical details on how this section is generated, please see the Glossary .

Complex functions with low coverage

Func name Function total lines Lines covered at runtime percentage covered Reached by fuzzers
h2::hpack::encoder::Encoder::encode_header 31 16 51.61%
h2::hpack::table::index_static 79 13 16.45%
parking_lot_core::parking_lot::park::parking_lot::raw_mutex::RawMutex::lock_slow::{closure:#0}, parking_lot::raw_mutex::RawMutex::lock_slow::{closure:#1}, parking_lot::raw_mutex::RawMutex::lock_slow::{closure:#2}::{closure:#0} 62 26 41.93%
parking_lot_core::parking_lot::park::parking_lot::condvar::Condvar::wait_until_internal::{closure:#0}, parking_lot::condvar::Condvar::wait_until_internal::{closure:#1}, parking_lot::condvar::Condvar::wait_until_internal::{closure:#2}::{closure:#0} 62 25 40.32%
tokio::runtime::blocking::pool::Spawner::spawn_task 45 20 44.44%
tokio::runtime::scheduler::multi_thread::queue::Stealalloc::sync::Arctokio::runtime::scheduler::multi_thread::handle::Handle::steal_into2 49 11 22.44%
tokio::runtime::time::handle::Handle::process_at_time 32 13 40.62%
tokio::sync::notify::Notify::inner_notify_waiters 32 9 28.12%
futures_core::task::__internal::atomic_waker::AtomicWaker::register 39 18 46.15%
h2::hpack::table::Table::index_occupied 32 12 37.5%
h2::proto::ping_pong::PingPong::send_pending_ping::fuzz_e2e::MockIo, h2::proto::streams::prioritize::Prioritizedbytes::bytes::Bytes 34 13 38.23%
h2::proto::streams::state::State::recv_open 38 17 44.73%

Files and Directories in report

This section shows which files and directories are considered in this report. The main reason for showing this is fuzz introspector may include more code in the reasoning than is desired. This section helps identify if too many files/directories are included, e.g. third party code, which may be irrelevant for the threat model. In the event too much is included, fuzz introspector supports a configuration file that can exclude data from the report. See the following link for more information on how to create a config file: link

Files in report

Source file Reached by Covered by
/src/http/src/response.rs [] []
/src/h2/tests/h2-support/src/assert.rs ['fuzzfuzz_http', 'fuzz_hpack', 'fuzz_client', 'fuzz_e2e'] []
/src/h2/src/server.rs ['fuzzfuzz_http', 'fuzz_hpack', 'fuzz_client', 'fuzz_e2e'] ['fuzzfuzz_http', 'fuzz_hpack', 'fuzz_client', 'fuzz_e2e']
/src/http/src/header/value.rs ['fuzzfuzz_http', 'fuzz_hpack', 'fuzz_client', 'fuzz_e2e'] ['fuzzfuzz_http', 'fuzz_hpack', 'fuzz_client', 'fuzz_e2e']
/src/h2/src/codec/error.rs [] []
/src/http/util/src/main.rs [] []
/src/h2/src/proto/error.rs ['fuzzfuzz_http', 'fuzz_hpack', 'fuzz_client', 'fuzz_e2e'] ['fuzz_e2e']
/src/http/src/lib.rs [] []
/src/http/src/uri/authority.rs [] []
/src/h2/tests/h2-tests/tests/client_request.rs ['fuzzfuzz_http', 'fuzz_hpack', 'fuzz_client', 'fuzz_e2e'] ['fuzz_client', 'fuzz_e2e']
/src/http/src/convert.rs ['fuzzfuzz_http', 'fuzz_hpack', 'fuzz_client', 'fuzz_e2e'] []
/src/h2/src/hpack/decoder.rs ['fuzzfuzz_http', 'fuzz_hpack', 'fuzz_client', 'fuzz_e2e'] ['fuzzfuzz_http', 'fuzz_hpack', 'fuzz_client', 'fuzz_e2e']
/src/h2/src/proto/streams/stream.rs [] []
/src/http/src/uri/tests.rs [] []
/src/h2/src/proto/streams/buffer.rs ['fuzz_hpack'] ['fuzz_hpack']
/src/h2/src/proto/streams/streams.rs ['fuzzfuzz_http', 'fuzz_hpack', 'fuzz_client', 'fuzz_e2e'] ['fuzzfuzz_http', 'fuzz_hpack', 'fuzz_client', 'fuzz_e2e']
/src/h2/src/proto/settings.rs ['fuzzfuzz_http', 'fuzz_hpack', 'fuzz_client', 'fuzz_e2e'] ['fuzzfuzz_http', 'fuzz_hpack', 'fuzz_client', 'fuzz_e2e']
/src/h2/src/frame/mod.rs ['fuzzfuzz_http', 'fuzz_hpack', 'fuzz_client', 'fuzz_e2e'] ['fuzz_e2e']
/src/h2/tests/h2-tests/tests/flow_control.rs ['fuzzfuzz_http', 'fuzz_hpack', 'fuzz_client', 'fuzz_e2e'] ['fuzz_client', 'fuzz_e2e']
/src/h2/src/codec/framed_read.rs ['fuzzfuzz_http', 'fuzz_hpack', 'fuzz_client', 'fuzz_e2e'] ['fuzzfuzz_http', 'fuzz_hpack', 'fuzz_client', 'fuzz_e2e']
/src/http/fuzz/src/fuzz_http.rs ['fuzzfuzz_http'] []
/src/h2/fuzz/fuzz_targets/fuzz_client.rs ['fuzz_client'] ['fuzz_client']
/src/h2/tests/h2-support/src/frames.rs ['fuzzfuzz_http', 'fuzz_hpack', 'fuzz_client', 'fuzz_e2e'] ['fuzzfuzz_http', 'fuzz_hpack', 'fuzz_client', 'fuzz_e2e']
/src/h2/tests/h2-tests/tests/server.rs ['fuzzfuzz_http', 'fuzz_hpack', 'fuzz_client', 'fuzz_e2e'] []
/src/h2/src/frame/go_away.rs [] []
/src/h2/src/frame/window_update.rs [] []
/src/h2/tests/h2-support/src/mock.rs ['fuzzfuzz_http', 'fuzz_hpack', 'fuzz_client', 'fuzz_e2e'] ['fuzzfuzz_http', 'fuzz_hpack', 'fuzz_client', 'fuzz_e2e']
/src/http/src/uri/port.rs [] []
/src/h2/src/hpack/test/fixture.rs [] []
/src/h2/tests/h2-tests/tests/hammer.rs [] []
/src/http/src/byte_str.rs ['fuzzfuzz_http', 'fuzz_hpack', 'fuzz_client', 'fuzz_e2e'] ['fuzzfuzz_http', 'fuzz_hpack', 'fuzz_client', 'fuzz_e2e']
/src/http/tests/status_code.rs ['fuzzfuzz_http', 'fuzz_hpack'] ['fuzzfuzz_http', 'fuzz_hpack']
/src/http/benches/src/method.rs [] []
/src/h2/tests/h2-tests/tests/stream_states.rs ['fuzzfuzz_http', 'fuzz_hpack', 'fuzz_client', 'fuzz_e2e'] []
/src/h2/src/frame/reset.rs [] []
/src/h2/tests/h2-tests/tests/codec_write.rs [] []
/src/h2/src/proto/streams/state.rs [] []
/src/h2/src/lib.rs ['fuzzfuzz_http', 'fuzz_hpack', 'fuzz_client', 'fuzz_e2e'] ['fuzz_client', 'fuzz_e2e']
/src/h2/fuzz/fuzz_targets/fuzz_hpack.rs ['fuzz_hpack'] []
/src/h2/src/hpack/header.rs ['fuzzfuzz_http', 'fuzz_hpack', 'fuzz_client', 'fuzz_e2e'] ['fuzzfuzz_http', 'fuzz_hpack', 'fuzz_client', 'fuzz_e2e']
/src/h2/src/proto/peer.rs [] []
/src/h2/src/frame/ping.rs [] []
/src/http/benches/src/header_map/basic.rs [] []
/src/h2/src/share.rs ['fuzzfuzz_http', 'fuzz_hpack', 'fuzz_client', 'fuzz_e2e'] ['fuzzfuzz_http', 'fuzz_hpack', 'fuzz_client', 'fuzz_e2e']
/src/h2/src/error.rs [] []
/src/h2/tests/h2-support/src/client_ext.rs ['fuzzfuzz_http', 'fuzz_hpack', 'fuzz_client', 'fuzz_e2e'] ['fuzz_hpack', 'fuzz_client', 'fuzz_e2e']
/src/h2/src/hpack/encoder.rs ['fuzzfuzz_http', 'fuzz_hpack', 'fuzz_client', 'fuzz_e2e'] ['fuzzfuzz_http', 'fuzz_hpack', 'fuzz_client', 'fuzz_e2e']
/src/h2/src/codec/mod.rs ['fuzzfuzz_http', 'fuzz_hpack', 'fuzz_client', 'fuzz_e2e'] ['fuzzfuzz_http', 'fuzz_hpack', 'fuzz_client', 'fuzz_e2e']
/src/h2/tests/h2-tests/tests/prioritization.rs ['fuzzfuzz_http', 'fuzz_hpack', 'fuzz_client', 'fuzz_e2e'] ['fuzz_client', 'fuzz_e2e']
/src/h2/src/frame/util.rs [] []
/src/http/src/request.rs ['fuzzfuzz_http', 'fuzz_hpack', 'fuzz_client', 'fuzz_e2e'] ['fuzzfuzz_http', 'fuzz_hpack', 'fuzz_client', 'fuzz_e2e']
/src/h2/src/proto/streams/store.rs ['fuzzfuzz_http', 'fuzz_hpack', 'fuzz_client', 'fuzz_e2e'] ['fuzzfuzz_http', 'fuzz_hpack', 'fuzz_client', 'fuzz_e2e']
/src/h2/src/frame/stream_id.rs [] []
/src/http/src/version.rs [] []
/src/h2/src/proto/ping_pong.rs ['fuzzfuzz_http', 'fuzz_hpack', 'fuzz_client', 'fuzz_e2e'] ['fuzzfuzz_http', 'fuzz_hpack', 'fuzz_client', 'fuzz_e2e']
/src/h2/tests/h2-tests/tests/codec_read.rs ['fuzzfuzz_http', 'fuzz_hpack', 'fuzz_client', 'fuzz_e2e'] []
/src/h2/src/hpack/huffman/mod.rs [] []
/src/h2/tests/h2-support/src/raw.rs ['fuzzfuzz_http', 'fuzz_hpack', 'fuzz_client', 'fuzz_e2e'] ['fuzz_client', 'fuzz_e2e']
/src/h2/src/proto/streams/recv.rs ['fuzzfuzz_http', 'fuzz_hpack', 'fuzz_client', 'fuzz_e2e'] ['fuzzfuzz_http', 'fuzz_hpack', 'fuzz_client', 'fuzz_e2e']
/src/http/src/error.rs [] []
/src/http/src/status.rs [] []
/src/h2/util/genhuff/src/main.rs [] []
/src/h2/tests/h2-tests/tests/ping_pong.rs ['fuzzfuzz_http', 'fuzz_hpack', 'fuzz_client', 'fuzz_e2e'] []
/src/h2/src/proto/streams/prioritize.rs ['fuzzfuzz_http', 'fuzz_hpack', 'fuzz_client', 'fuzz_e2e'] ['fuzzfuzz_http', 'fuzz_hpack', 'fuzz_client', 'fuzz_e2e']
/src/h2/src/frame/data.rs [] []
/src/http/src/uri/builder.rs ['fuzzfuzz_http', 'fuzz_hpack', 'fuzz_client', 'fuzz_e2e'] ['fuzzfuzz_http', 'fuzz_hpack', 'fuzz_client', 'fuzz_e2e']
/src/h2/tests/h2-tests/tests/informational_responses.rs [] []
/src/h2/src/hpack/table.rs ['fuzzfuzz_http', 'fuzz_hpack', 'fuzz_client', 'fuzz_e2e'] ['fuzzfuzz_http', 'fuzz_hpack', 'fuzz_client', 'fuzz_e2e']
/src/h2/fuzz/fuzz_targets/fuzz_e2e.rs ['fuzz_e2e'] ['fuzz_e2e']
/src/h2/tests/h2-support/src/util.rs ['fuzzfuzz_http', 'fuzz_hpack', 'fuzz_client', 'fuzz_e2e'] ['fuzz_client', 'fuzz_e2e']
/src/http/src/header/name.rs ['fuzz_hpack'] ['fuzz_hpack']
/src/h2/tests/h2-tests/tests/trailers.rs [] []
/src/http/benches/src/header_name2.rs [] []
/src/http/src/uri/path.rs [] []
/src/h2/src/frame/head.rs [] []
/src/h2/tests/h2-support/src/prelude.rs [] []
/src/http/src/header/map.rs ['fuzzfuzz_http', 'fuzz_hpack', 'fuzz_client', 'fuzz_e2e'] ['fuzzfuzz_http', 'fuzz_hpack', 'fuzz_client', 'fuzz_e2e']
/src/h2/src/frame/reason.rs [] []
/src/h2/src/hpack/test/fuzz.rs [] []
/src/h2/src/fuzz_bridge.rs ['fuzz_hpack'] ['fuzz_hpack']
/src/http/benches/src/header_map/vec_map.rs [] []
/src/h2/tests/h2-support/src/future_ext.rs ['fuzzfuzz_http', 'fuzz_hpack', 'fuzz_client', 'fuzz_e2e'] ['fuzz_client', 'fuzz_e2e']
/src/h2/src/ext.rs ['fuzzfuzz_http', 'fuzz_hpack', 'fuzz_client', 'fuzz_e2e'] ['fuzzfuzz_http', 'fuzz_hpack', 'fuzz_client', 'fuzz_e2e']
/src/h2/src/proto/go_away.rs [] []
/src/h2/benches/main.rs [] []
/src/http/benches/src/uri.rs [] []
/src/h2/src/proto/streams/counts.rs [] []
/src/h2/src/codec/framed_write.rs [] []
/src/h2/tests/h2-tests/tests/push_promise.rs ['fuzzfuzz_http', 'fuzz_hpack', 'fuzz_client', 'fuzz_e2e'] []
/src/http/benches/src/header_name.rs [] []
/src/h2/src/frame/headers.rs ['fuzzfuzz_http', 'fuzz_hpack', 'fuzz_client', 'fuzz_e2e'] ['fuzzfuzz_http', 'fuzz_hpack', 'fuzz_client', 'fuzz_e2e']
/src/h2/tests/h2-support/src/trace.rs [] []
/src/http/tests/header_map.rs [] []
/src/h2/src/client.rs ['fuzzfuzz_http', 'fuzz_hpack', 'fuzz_client', 'fuzz_e2e'] ['fuzzfuzz_http', 'fuzz_hpack', 'fuzz_client', 'fuzz_e2e']
/src/h2/src/frame/priority.rs [] []
/src/h2/src/proto/streams/send.rs [] []
/src/http/src/method.rs ['fuzz_hpack'] ['fuzz_hpack']
/src/h2/src/proto/streams/mod.rs [] []
/src/http/src/uri/scheme.rs [] []
/src/http/tests/header_map_fuzz.rs [] []
/src/http/src/uri/mod.rs [] []
/src/h2/tests/h2-support/src/lib.rs [] []
/src/h2/src/frame/settings.rs ['fuzzfuzz_http', 'fuzz_hpack', 'fuzz_client', 'fuzz_e2e'] ['fuzzfuzz_http', 'fuzz_hpack', 'fuzz_client', 'fuzz_e2e']
/src/http/benches/src/header_value.rs [] []
/src/http/src/extensions.rs ['fuzz_hpack'] ['fuzz_hpack']
/src/h2/src/proto/connection.rs ['fuzzfuzz_http', 'fuzz_hpack', 'fuzz_client', 'fuzz_e2e'] ['fuzzfuzz_http', 'fuzz_hpack', 'fuzz_client', 'fuzz_e2e']
/src/h2/src/proto/streams/flow_control.rs ['fuzzfuzz_http', 'fuzz_hpack', 'fuzz_client', 'fuzz_e2e'] ['fuzzfuzz_http', 'fuzz_hpack', 'fuzz_client', 'fuzz_e2e']

Directories in report

Directory
/src/http/benches/src/
/src/h2/src/codec/
/src/h2/util/genhuff/src/
/src/http/src/uri/
/src/http/util/src/
/src/http/src/header/
/src/h2/src/
/src/h2/src/hpack/huffman/
/src/h2/tests/h2-tests/tests/
/src/h2/tests/h2-support/src/
/src/h2/src/frame/
/src/h2/benches/
/src/h2/fuzz/fuzz_targets/
/src/http/fuzz/src/
/src/http/benches/src/header_map/
/src/h2/src/proto/
/src/h2/src/hpack/test/
/src/h2/src/proto/streams/
/src/http/tests/
/src/h2/src/hpack/
/src/http/src/