From 76ccdcd5d0a9731e9079d174ead64cbaf647ee9d Mon Sep 17 00:00:00 2001 From: Matt Morehouse Date: Tue, 22 Aug 2023 16:17:07 -0500 Subject: [PATCH] fuzz: target for onion_message Fuzz the decoding and encoding of onion_message. --- tests/fuzz/fuzz-wire-onion_message.c | 38 ++++++++++++++++++++++++++++ 1 file changed, 38 insertions(+) create mode 100644 tests/fuzz/fuzz-wire-onion_message.c diff --git a/tests/fuzz/fuzz-wire-onion_message.c b/tests/fuzz/fuzz-wire-onion_message.c new file mode 100644 index 000000000..78a555730 --- /dev/null +++ b/tests/fuzz/fuzz-wire-onion_message.c @@ -0,0 +1,38 @@ +#include "config.h" +#include +#include +#include +#include + +struct onion_message { + struct pubkey blinding; + u8 *onionmsg; +}; + +static void *encode(const tal_t *ctx, const struct onion_message *s) +{ + return towire_onion_message(ctx, &s->blinding, s->onionmsg); +} + +static struct onion_message *decode(const tal_t *ctx, const void *p) +{ + struct onion_message *s = tal(ctx, struct onion_message); + + if (fromwire_onion_message(s, p, &s->blinding, &s->onionmsg)) + return s; + return tal_free(s); +} + +static bool equal(const struct onion_message *x, const struct onion_message *y) +{ + if (memcmp(&x->blinding, &y->blinding, sizeof(x->blinding)) != 0) + return false; + return memeq(x->onionmsg, tal_bytelen(x->onionmsg), y->onionmsg, + tal_bytelen(y->onionmsg)); +} + +void run(const u8 *data, size_t size) +{ + test_decode_encode(data, size, WIRE_ONION_MESSAGE, + struct onion_message); +}