mirror of
https://github.com/ElementsProject/lightning.git
synced 2025-01-18 21:35:11 +01:00
fuzz: target for tx_add_input
Fuzz the decoding and encoding of tx_add_input.
This commit is contained in:
parent
82c719142e
commit
dac211c73e
45
tests/fuzz/fuzz-wire-tx_add_input.c
Normal file
45
tests/fuzz/fuzz-wire-tx_add_input.c
Normal file
@ -0,0 +1,45 @@
|
||||
#include "config.h"
|
||||
#include <ccan/mem/mem.h>
|
||||
#include <stdint.h>
|
||||
#include <tests/fuzz/libfuzz.h>
|
||||
#include <tests/fuzz/wire.h>
|
||||
#include <wire/peer_wire.h>
|
||||
|
||||
struct tx_add_input {
|
||||
struct channel_id channel_id;
|
||||
u64 serial_id;
|
||||
u32 prevtx_vout;
|
||||
u32 sequence;
|
||||
u8 *prevtx;
|
||||
};
|
||||
|
||||
static void *encode(const tal_t *ctx, const struct tx_add_input *s)
|
||||
{
|
||||
return towire_tx_add_input(ctx, &s->channel_id, s->serial_id, s->prevtx,
|
||||
s->prevtx_vout, s->sequence);
|
||||
}
|
||||
|
||||
static struct tx_add_input *decode(const tal_t *ctx, const void *p)
|
||||
{
|
||||
struct tx_add_input *s = tal(ctx, struct tx_add_input);
|
||||
|
||||
if (fromwire_tx_add_input(s, p, &s->channel_id, &s->serial_id,
|
||||
&s->prevtx, &s->prevtx_vout, &s->sequence))
|
||||
return s;
|
||||
return tal_free(s);
|
||||
}
|
||||
|
||||
static bool equal(const struct tx_add_input *x, const struct tx_add_input *y)
|
||||
{
|
||||
size_t upto_prevtx = (uintptr_t)&x->prevtx - (uintptr_t)x;
|
||||
if (memcmp(x, y, upto_prevtx) != 0)
|
||||
return false;
|
||||
|
||||
return memeq(x->prevtx, tal_bytelen(x->prevtx), y->prevtx,
|
||||
tal_bytelen(y->prevtx));
|
||||
}
|
||||
|
||||
void run(const u8 *data, size_t size)
|
||||
{
|
||||
test_decode_encode(data, size, WIRE_TX_ADD_INPUT, struct tx_add_input);
|
||||
}
|
Loading…
Reference in New Issue
Block a user