SSLCertificate basic fuzzer.

This change simply calls through all code paths in the SSLCertificate interface
after passing in an untrusted PEM string. Corpus will follow in another CL.

Bug: webrtc:10395
Change-Id: I001642fa89a84ce01505780f5e76f01a0e46a785
Reviewed-on: https://webrtc-review.googlesource.com/c/src/+/127640
Commit-Queue: Benjamin Wright <benwright@webrtc.org>
Reviewed-by: Steve Anton <steveanton@webrtc.org>
Cr-Commit-Position: refs/heads/master@{#27118}
This commit is contained in:
Benjamin Wright
2019-03-13 16:59:54 -07:00
committed by Commit Bot
parent 3aa584ff11
commit d5e1c372c9
2 changed files with 56 additions and 0 deletions

View File

@ -619,3 +619,12 @@ webrtc_fuzzer_test("rtp_header_parser_fuzzer") {
"../../modules/rtp_rtcp",
]
}
webrtc_fuzzer_test("ssl_certificate_fuzzer") {
sources = [
"rtp_header_parser_fuzzer.cc",
]
deps = [
"../../modules/rtp_rtcp",
]
}

View File

@ -0,0 +1,47 @@
/*
* Copyright (c) 2019 The WebRTC project authors. All Rights Reserved.
*
* Use of this source code is governed by a BSD-style license
* that can be found in the LICENSE file in the root of the source
* tree. An additional intellectual property rights grant can be found
* in the file PATENTS. All contributing project authors may
* be found in the AUTHORS file in the root of the source tree.
*/
#include <stddef.h>
#include <stdint.h>
#include <string>
#include "rtc_base/ssl_certificate.h"
#include "rtc_base/string_encode.h"
namespace webrtc {
void FuzzOneInput(const uint8_t* data, size_t size) {
std::string pem_certificate(reinterpret_cast<const char*>(data), size);
std::unique_ptr<rtc::SSLCertificate> cert =
rtc::SSLCertificate::FromPEMString(pem_certificate);
if (cert == nullptr) {
return;
}
cert->Clone();
cert->GetStats();
cert->ToPEMString();
cert->CertificateExpirationTime();
std::string algorithm;
cert->GetSignatureDigestAlgorithm(algorithm);
unsigned char digest[rtc::MessageDigest::kMaxSize];
size_t digest_len;
cert->ComputeDigest(algorithm, digest, rtc::MessageDigest::kMaxSize,
&digest_len);
rtc::Buffer der_buffer;
cert->ToDER(&der_buffer);
}
} // namespace webrtc