aboutsummaryrefslogtreecommitdiffstats
path: root/src/fuzzer
diff options
context:
space:
mode:
authorJack Lloyd <[email protected]>2019-05-07 07:36:43 -0400
committerJack Lloyd <[email protected]>2019-05-08 18:18:47 -0400
commit959f14f63b4a995071065002d6d9be1b2085d29b (patch)
tree19e0bb7ae6ade7d4434b86be9229014ce41cc5d6 /src/fuzzer
parent300afa13058ff7b063f4b92dcf1ddc45cf0e881e (diff)
Fix X509_DN comparison
An issue in #1936 indicated that X509_DN operator< was not behaving correctly. Indeed, DNs could compare in such a way that DN1 < DN2 && DN2 < DN1. STL containers do not like this.
Diffstat (limited to 'src/fuzzer')
-rw-r--r--src/fuzzer/x509_dn.cpp46
1 files changed, 46 insertions, 0 deletions
diff --git a/src/fuzzer/x509_dn.cpp b/src/fuzzer/x509_dn.cpp
new file mode 100644
index 000000000..dca6352e9
--- /dev/null
+++ b/src/fuzzer/x509_dn.cpp
@@ -0,0 +1,46 @@
+/*
+* (C) 2019 Jack Lloyd
+*
+* Botan is released under the Simplified BSD License (see license.txt)
+*/
+
+#include "fuzzers.h"
+#include <botan/x509_dn.h>
+#include <botan/ber_dec.h>
+#include <botan/hex.h>
+
+void fuzz(const uint8_t in[], size_t len)
+ {
+ const size_t half = len / 2;
+ Botan::X509_DN dn1;
+ Botan::X509_DN dn2;
+
+ try
+ {
+ Botan::BER_Decoder ber1(in, half);
+ dn1.decode_from(ber1);
+ ber1.verify_end();
+
+ Botan::BER_Decoder ber2(in + half, half);
+ dn2.decode_from(ber2);
+ ber2.verify_end();
+ }
+ catch(...) { return; }
+
+ const bool eq = dn1 == dn2;
+ const bool lt1 = dn1 < dn2;
+ const bool lt2 = dn2 < dn1;
+
+ if(lt1 == false && lt2 == false)
+ {
+ FUZZER_ASSERT_TRUE(eq);
+ }
+ else
+ {
+ // one is less than the other
+ FUZZER_ASSERT_TRUE(lt1 || lt2);
+
+ // it is not the case that both are less than the other
+ FUZZER_ASSERT_TRUE(!lt1 || !lt2);
+ }
+ }