Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Add fuzzing audit blog post #5827

Merged
merged 13 commits into from
Dec 20, 2024
Merged
Show file tree
Hide file tree
Changes from 12 commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
71 changes: 71 additions & 0 deletions content/en/blog/2024/fuzzing-audit-results.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,71 @@
---
title: OpenTelemetry Collector Completes Fuzzing Audit
linkTitle: Fuzzing Audit Results
date: 2024-12-20
author: '[Adam Korczynski](https://github.com/AdamKorcz)'

Check warning on line 5 in content/en/blog/2024/fuzzing-audit-results.md

View workflow job for this annotation

GitHub Actions / SPELLING check

Unknown word (Korczynski) Suggestions: (Korzybski)
issue: 5798
sig: GC
svrnm marked this conversation as resolved.
Show resolved Hide resolved
---

OpenTelemetry is happy to announce the completion of the Collector's fuzzing
audit sponsored by [the CNCF](https://www.cncf.io/) and carried out by
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Catching up on this: @AdamKorcz - do you have a link that supports the "CNCF sponsored this" claim?

Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

@chalin Please send me an email at [email protected] and I can put you in touch with someone in the CNCF who can confirm this.

[Ada Logics](https://adalogics.com/). The audit marks a significant step in the
OpenTelemetry project, ensuring the security and reliability of the Collector
for its users.

## What is fuzzing?

Fuzzing is a testing technique that executes an API with a high amount of
pseudo-random inputs and observes the API's behavior. The technique has
increased in popularity due to its empirical success in finding security
vulnerabilities and reliability issues. Fuzzing initially developed with a focus
on testing software implemented in memory-unsafe languages, where it has been
most productive. However, in recent years, fuzzing has expanded to memory-safe
languages as well.

Over several years, the CNCF has invested in fuzzing for its ecosystem. This
testing has found numerous security vulnerabilities in widely used projects such
as Helm (CVE-2022-36055, CVE-2022-23524, CVE-2022-23526, CVE-2022-23525), the
Notary project (CVE-2023-25656), containerd (CVE-2023-25153), Crossplane

Check warning on line 29 in content/en/blog/2024/fuzzing-audit-results.md

View workflow job for this annotation

GitHub Actions / SPELLING check

Unknown word (containerd) Suggestions: (contained, container, containers, containerp, containerdb)
(CVE-2023-28494, CVE-2023-27483) and Flux (CVE-2022-36049).

## OSS-Fuzz

To initiate the audit, Ada Logics auditors integrated the OpenTelemetry
Collector into [OSS-Fuzz](https://github.com/google/oss-fuzz). OSS-Fuzz is a
service offered by Google to critical open source projects, free of charge. The
service runs a project's fuzzers with excess resources multiple times per week.
If OSS-Fuzz finds a crash, it notifies the project. It then checks if the
project has fixed the crash upstream and if so, marks the issue(s) as fixed. The
whole workflow happens continuously on Google's fuzzing infrastructure,
supported by thousands of CPU cores. These testing resources outperform what
developers or malicious threat actors can muster.

## The tests

After the Ada Logics team integrated OpenTelemetry into OSS-Fuzz, the next step
was to write a series of fuzz tests for the OpenTelemetry Collector. The
auditors wrote 49 fuzz tests for core components of the Collector, as well as
several receivers and processors in the `opentelemetry-collector-contrib`
repository.

The fuzz tests were left to run while the audit team observed their health in
production. At the completion of the fuzzing audit, the 49 fuzz tests on the
OSS-Fuzz platform were healthy.

To ensure continued reliability, the fuzz testing continues on the Collector
even though the audit is complete.

## The results so far

Fuzz testing for the Collector is ongoing, allowing for changes to the project
to be tested as well. As of the date of this post, no crashes have been
detected.

But the work is not done! The Ada Logics team created the Collector's fuzzing
setup as a reference implementation that other OpenTelemetry subprojects can
rely on to create their own fuzz testing, ensuring greater stability for the
project as a whole.

For more insight into the audit process, see the
[published summary](https://github.com/open-telemetry/community/blob/main/reports/ADA_Logics-collector-fuzzing-audit-2024.pdf).
12 changes: 12 additions & 0 deletions static/refcache.json
Original file line number Diff line number Diff line change
Expand Up @@ -59,6 +59,10 @@
"StatusCode": 200,
"LastSeen": "2024-08-09T10:46:17.075695-04:00"
},
"https://adalogics.com/": {
"StatusCode": 200,
"LastSeen": "2024-12-20T14:53:22.847313555Z"
},
"https://adri-v.medium.com/43dca4a857a0": {
"StatusCode": 200,
"LastSeen": "2024-02-23T23:30:53.006527-05:00"
Expand Down Expand Up @@ -3899,6 +3903,10 @@
"StatusCode": 200,
"LastSeen": "2024-08-06T15:19:48.633928+02:00"
},
"https://github.com/AdamKorcz": {
"StatusCode": 200,
"LastSeen": "2024-12-20T14:53:22.289195232Z"
},
"https://github.com/AkhigbeEromo": {
"StatusCode": 200,
"LastSeen": "2024-12-17T15:37:25.440239-05:00"
Expand Down Expand Up @@ -5251,6 +5259,10 @@
"StatusCode": 200,
"LastSeen": "2024-11-07T20:32:07.730871-05:00"
},
"https://github.com/google/oss-fuzz": {
"StatusCode": 200,
"LastSeen": "2024-12-20T14:53:23.420338032Z"
},
"https://github.com/google/pprof": {
"StatusCode": 200,
"LastSeen": "2024-10-24T15:10:16.695786+02:00"
Expand Down
Loading