mirror of
https://github.com/ElementsProject/lightning.git
synced 2025-01-18 05:12:45 +01:00
onchaind: test stressful input.
In particular, this made valgrind OOM, and chewed much CPU. I dumped the input and output into a file to allow easy replay. This will break as soon as we change onchaind's wire format, but it will serve its purpose until then! Signed-off-by: Rusty Russell <rusty@rustcorp.com.au>
This commit is contained in:
parent
af8eabb9a7
commit
f22d719d2c
@ -21,6 +21,21 @@ update-mocks: $(ONCHAIND_TEST_SRC:%=update-mocks/%)
|
|||||||
|
|
||||||
$(ONCHAIND_TEST_PROGRAMS): $(ONCHAIND_TEST_COMMON_OBJS) $(BITCOIN_OBJS)
|
$(ONCHAIND_TEST_PROGRAMS): $(ONCHAIND_TEST_COMMON_OBJS) $(BITCOIN_OBJS)
|
||||||
|
|
||||||
|
# This needs many more objs:
|
||||||
|
onchaind/test/run-onchainstress: \
|
||||||
|
common/htlc_tx.o \
|
||||||
|
common/derive_basepoints.o \
|
||||||
|
common/daemon.o \
|
||||||
|
common/htlc_wire.o \
|
||||||
|
common/initial_commit_tx.o \
|
||||||
|
common/key_derive.o \
|
||||||
|
common/keyset.o \
|
||||||
|
common/permute_tx.o \
|
||||||
|
common/subdaemon.o \
|
||||||
|
common/wallet.o \
|
||||||
|
wire/towire.o \
|
||||||
|
wire/fromwire.o
|
||||||
|
|
||||||
# Test objects depend on ../ src and headers.
|
# Test objects depend on ../ src and headers.
|
||||||
$(ONCHAIND_TEST_OBJS): $(ONCHAIND_HEADERS) $(ONCHAIND_SRC)
|
$(ONCHAIND_TEST_OBJS): $(ONCHAIND_HEADERS) $(ONCHAIND_SRC)
|
||||||
|
|
||||||
|
BIN
onchaind/test/onchainstress-data.gz
Normal file
BIN
onchaind/test/onchainstress-data.gz
Normal file
Binary file not shown.
224
onchaind/test/run-onchainstress.c
Normal file
224
onchaind/test/run-onchainstress.c
Normal file
@ -0,0 +1,224 @@
|
|||||||
|
#include "../onchaind.c"
|
||||||
|
#include "../onchaind_wiregen.c"
|
||||||
|
#include "../onchaind_wire.c"
|
||||||
|
#include "../../hsmd/hsmd_wiregen.c"
|
||||||
|
#include <ccan/str/hex/hex.h>
|
||||||
|
#include <common/dev_disconnect.h>
|
||||||
|
#include <common/onionreply.h>
|
||||||
|
#include <err.h>
|
||||||
|
#include <zlib.h>
|
||||||
|
|
||||||
|
volatile bool logging_io;
|
||||||
|
struct backtrace_state *backtrace_state;
|
||||||
|
|
||||||
|
/* AUTOGENERATED MOCKS START */
|
||||||
|
/* Generated stub for dup_onionreply */
|
||||||
|
struct onionreply *dup_onionreply(const tal_t *ctx UNNEEDED,
|
||||||
|
const struct onionreply *r TAKES UNNEEDED)
|
||||||
|
{ fprintf(stderr, "dup_onionreply called!\n"); abort(); }
|
||||||
|
/* Generated stub for fromwire_bip32_key_version */
|
||||||
|
void fromwire_bip32_key_version(const u8 **cursor UNNEEDED, size_t *max UNNEEDED,
|
||||||
|
struct bip32_key_version *version UNNEEDED)
|
||||||
|
{ fprintf(stderr, "fromwire_bip32_key_version called!\n"); abort(); }
|
||||||
|
/* Generated stub for fromwire_chain_coin_mvt */
|
||||||
|
void fromwire_chain_coin_mvt(const u8 **cursor UNNEEDED, size_t *max UNNEEDED, struct chain_coin_mvt *mvt UNNEEDED)
|
||||||
|
{ fprintf(stderr, "fromwire_chain_coin_mvt called!\n"); abort(); }
|
||||||
|
/* Generated stub for fromwire_ext_key */
|
||||||
|
void fromwire_ext_key(const u8 **cursor UNNEEDED, size_t *max UNNEEDED, struct ext_key *bip32 UNNEEDED)
|
||||||
|
{ fprintf(stderr, "fromwire_ext_key called!\n"); abort(); }
|
||||||
|
/* Generated stub for fromwire_node_id */
|
||||||
|
void fromwire_node_id(const u8 **cursor UNNEEDED, size_t *max UNNEEDED, struct node_id *id UNNEEDED)
|
||||||
|
{ fprintf(stderr, "fromwire_node_id called!\n"); abort(); }
|
||||||
|
/* Generated stub for fromwire_onionreply */
|
||||||
|
struct onionreply *fromwire_onionreply(const tal_t *ctx UNNEEDED,
|
||||||
|
const u8 **cursor UNNEEDED, size_t *max UNNEEDED)
|
||||||
|
{ fprintf(stderr, "fromwire_onionreply called!\n"); abort(); }
|
||||||
|
/* Generated stub for fromwire_utxo */
|
||||||
|
struct utxo *fromwire_utxo(const tal_t *ctx UNNEEDED, const u8 **ptr UNNEEDED, size_t *max UNNEEDED)
|
||||||
|
{ fprintf(stderr, "fromwire_utxo called!\n"); abort(); }
|
||||||
|
/* Generated stub for master_badmsg */
|
||||||
|
void master_badmsg(u32 type_expected UNNEEDED, const u8 *msg)
|
||||||
|
{ fprintf(stderr, "master_badmsg called!\n"); abort(); }
|
||||||
|
/* Generated stub for memleak_find_allocations */
|
||||||
|
struct htable *memleak_find_allocations(const tal_t *ctx UNNEEDED,
|
||||||
|
const void *exclude1 UNNEEDED,
|
||||||
|
const void *exclude2 UNNEEDED)
|
||||||
|
{ fprintf(stderr, "memleak_find_allocations called!\n"); abort(); }
|
||||||
|
/* Generated stub for memleak_get */
|
||||||
|
const void *memleak_get(struct htable *memtable UNNEEDED, const uintptr_t **backtrace UNNEEDED)
|
||||||
|
{ fprintf(stderr, "memleak_get called!\n"); abort(); }
|
||||||
|
/* Generated stub for memleak_init */
|
||||||
|
void memleak_init(void)
|
||||||
|
{ fprintf(stderr, "memleak_init called!\n"); abort(); }
|
||||||
|
/* Generated stub for memleak_remove_region */
|
||||||
|
void memleak_remove_region(struct htable *memtable UNNEEDED,
|
||||||
|
const void *p UNNEEDED, size_t bytelen UNNEEDED)
|
||||||
|
{ fprintf(stderr, "memleak_remove_region called!\n"); abort(); }
|
||||||
|
/* Generated stub for new_coin_penalty_sat */
|
||||||
|
struct chain_coin_mvt *new_coin_penalty_sat(const tal_t *ctx UNNEEDED,
|
||||||
|
const char *account_name UNNEEDED,
|
||||||
|
const struct bitcoin_txid *txid UNNEEDED,
|
||||||
|
const struct bitcoin_txid *out_txid UNNEEDED,
|
||||||
|
u32 vout UNNEEDED,
|
||||||
|
u32 blockheight UNNEEDED,
|
||||||
|
struct amount_sat amount UNNEEDED)
|
||||||
|
{ fprintf(stderr, "new_coin_penalty_sat called!\n"); abort(); }
|
||||||
|
/* Generated stub for new_coin_withdrawal */
|
||||||
|
struct chain_coin_mvt *new_coin_withdrawal(const tal_t *ctx UNNEEDED,
|
||||||
|
const char *account_name UNNEEDED,
|
||||||
|
const struct bitcoin_txid *tx_txid UNNEEDED,
|
||||||
|
const struct bitcoin_txid *out_txid UNNEEDED,
|
||||||
|
u32 vout UNNEEDED,
|
||||||
|
u32 blockheight UNNEEDED,
|
||||||
|
struct amount_msat amount UNNEEDED)
|
||||||
|
{ fprintf(stderr, "new_coin_withdrawal called!\n"); abort(); }
|
||||||
|
/* Generated stub for status_failed */
|
||||||
|
void status_failed(enum status_failreason code UNNEEDED,
|
||||||
|
const char *fmt UNNEEDED, ...)
|
||||||
|
{ fprintf(stderr, "status_failed called!\n"); abort(); }
|
||||||
|
/* Generated stub for status_vfmt */
|
||||||
|
void status_vfmt(enum log_level level UNNEEDED,
|
||||||
|
const struct node_id *peer UNNEEDED,
|
||||||
|
const char *fmt UNNEEDED, va_list ap UNNEEDED)
|
||||||
|
{ fprintf(stderr, "status_vfmt called!\n"); abort(); }
|
||||||
|
/* Generated stub for towire_bip32_key_version */
|
||||||
|
void towire_bip32_key_version(u8 **cursor UNNEEDED, const struct bip32_key_version *version UNNEEDED)
|
||||||
|
{ fprintf(stderr, "towire_bip32_key_version called!\n"); abort(); }
|
||||||
|
/* Generated stub for towire_ext_key */
|
||||||
|
void towire_ext_key(u8 **pptr UNNEEDED, const struct ext_key *bip32 UNNEEDED)
|
||||||
|
{ fprintf(stderr, "towire_ext_key called!\n"); abort(); }
|
||||||
|
/* Generated stub for towire_node_id */
|
||||||
|
void towire_node_id(u8 **pptr UNNEEDED, const struct node_id *id UNNEEDED)
|
||||||
|
{ fprintf(stderr, "towire_node_id called!\n"); abort(); }
|
||||||
|
/* Generated stub for towire_onionreply */
|
||||||
|
void towire_onionreply(u8 **cursor UNNEEDED, const struct onionreply *r UNNEEDED)
|
||||||
|
{ fprintf(stderr, "towire_onionreply called!\n"); abort(); }
|
||||||
|
/* Generated stub for towire_utxo */
|
||||||
|
void towire_utxo(u8 **pptr UNNEEDED, const struct utxo *utxo UNNEEDED)
|
||||||
|
{ fprintf(stderr, "towire_utxo called!\n"); abort(); }
|
||||||
|
/* Generated stub for version */
|
||||||
|
const char *version(void)
|
||||||
|
{ fprintf(stderr, "version called!\n"); abort(); }
|
||||||
|
/* AUTOGENERATED MOCKS END */
|
||||||
|
|
||||||
|
#if DEVELOPER
|
||||||
|
/* Generated stub for dev_disconnect_init */
|
||||||
|
void dev_disconnect_init(int fd UNNEEDED)
|
||||||
|
{ fprintf(stderr, "dev_disconnect_init called!\n"); abort(); }
|
||||||
|
#endif
|
||||||
|
|
||||||
|
/* Noops */
|
||||||
|
void status_setup_sync(int fd UNNEEDED)
|
||||||
|
{
|
||||||
|
}
|
||||||
|
void status_fmt(enum log_level level,
|
||||||
|
const struct node_id *peer,
|
||||||
|
const char *fmt, ...)
|
||||||
|
{
|
||||||
|
}
|
||||||
|
void *notleak_(const void *ptr UNNEEDED, bool plus_children UNNEEDED)
|
||||||
|
{
|
||||||
|
return (void *)ptr;
|
||||||
|
}
|
||||||
|
void peer_billboard(bool perm UNNEEDED, const char *fmt UNNEEDED, ...)
|
||||||
|
{
|
||||||
|
}
|
||||||
|
struct chain_coin_mvt *new_coin_chain_fees(const tal_t *ctx UNNEEDED,
|
||||||
|
const char *account_name UNNEEDED,
|
||||||
|
const struct bitcoin_txid *tx_txid UNNEEDED,
|
||||||
|
u32 blockheight UNNEEDED,
|
||||||
|
struct amount_msat amount UNNEEDED)
|
||||||
|
{
|
||||||
|
return NULL;
|
||||||
|
}
|
||||||
|
|
||||||
|
/* Generated stub for new_coin_chain_fees_sat */
|
||||||
|
struct chain_coin_mvt *new_coin_chain_fees_sat(const tal_t *ctx UNNEEDED,
|
||||||
|
const char *account_name UNNEEDED,
|
||||||
|
const struct bitcoin_txid *tx_txid UNNEEDED,
|
||||||
|
u32 blockheight UNNEEDED,
|
||||||
|
struct amount_sat amount UNNEEDED)
|
||||||
|
{
|
||||||
|
return NULL;
|
||||||
|
}
|
||||||
|
/* Generated stub for new_coin_journal_entry */
|
||||||
|
struct chain_coin_mvt *new_coin_journal_entry(const tal_t *ctx UNNEEDED,
|
||||||
|
const char *account_name UNNEEDED,
|
||||||
|
const struct bitcoin_txid *txid UNNEEDED,
|
||||||
|
const struct bitcoin_txid *out_txid UNNEEDED,
|
||||||
|
u32 vout UNNEEDED,
|
||||||
|
u32 blockheight UNNEEDED,
|
||||||
|
struct amount_msat amount UNNEEDED,
|
||||||
|
bool is_credit UNNEEDED)
|
||||||
|
{
|
||||||
|
return NULL;
|
||||||
|
}
|
||||||
|
struct chain_coin_mvt *new_coin_onchain_htlc_sat(const tal_t *ctx UNNEEDED,
|
||||||
|
const char *account_name UNNEEDED,
|
||||||
|
const struct bitcoin_txid *txid UNNEEDED,
|
||||||
|
const struct bitcoin_txid *out_txid UNNEEDED,
|
||||||
|
u32 vout UNNEEDED,
|
||||||
|
struct sha256 payment_hash UNNEEDED,
|
||||||
|
u32 blockheight UNNEEDED,
|
||||||
|
struct amount_sat amount UNNEEDED,
|
||||||
|
bool is_credit UNNEEDED)
|
||||||
|
{
|
||||||
|
return NULL;
|
||||||
|
}
|
||||||
|
struct chain_coin_mvt *new_coin_withdrawal_sat(const tal_t *ctx UNNEEDED,
|
||||||
|
const char *account_name UNNEEDED,
|
||||||
|
const struct bitcoin_txid *tx_txid UNNEEDED,
|
||||||
|
const struct bitcoin_txid *out_txid UNNEEDED,
|
||||||
|
u32 vout UNNEEDED,
|
||||||
|
u32 blockheight UNNEEDED,
|
||||||
|
struct amount_sat amount UNNEEDED)
|
||||||
|
{
|
||||||
|
return NULL;
|
||||||
|
}
|
||||||
|
void towire_chain_coin_mvt(u8 **pptr UNNEEDED, const struct chain_coin_mvt *mvt UNNEEDED)
|
||||||
|
{
|
||||||
|
}
|
||||||
|
|
||||||
|
bool wire_sync_write(int fd, const void *msg TAKES)
|
||||||
|
{
|
||||||
|
if (taken(msg))
|
||||||
|
tal_free(msg);
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
|
||||||
|
u8 *wire_sync_read(const tal_t *ctx, int fd)
|
||||||
|
{
|
||||||
|
char line[5000];
|
||||||
|
u8 *ret;
|
||||||
|
static gzFile stream;
|
||||||
|
size_t hexlen;
|
||||||
|
|
||||||
|
/* Don't run this under valgrind in CI: takes too long! */
|
||||||
|
if (getenv("VALGRIND") && streq(getenv("VALGRIND"), "1"))
|
||||||
|
goto exit;
|
||||||
|
|
||||||
|
if (!stream) {
|
||||||
|
stream = gzopen("onchaind/test/onchainstress-data.gz", "rb");
|
||||||
|
if (!stream)
|
||||||
|
err(1, "opening onchaind/test/onchainstress-data.gz");
|
||||||
|
}
|
||||||
|
|
||||||
|
do {
|
||||||
|
if (!gzgets(stream, line, sizeof(line)))
|
||||||
|
goto exit;
|
||||||
|
} while (!strstarts(line, "read "));
|
||||||
|
|
||||||
|
/* Ignore prefix and \n at end */
|
||||||
|
hexlen = strlen(line) - strlen("read ") - 1;
|
||||||
|
ret = tal_arr(ctx, u8, hex_data_size(hexlen));
|
||||||
|
if (!hex_decode(line + strlen("read "), hexlen, ret, tal_bytelen(ret)))
|
||||||
|
errx(1, "Bad hex string '%s'", line);
|
||||||
|
return ret;
|
||||||
|
|
||||||
|
exit:
|
||||||
|
daemon_shutdown();
|
||||||
|
/* Free top-level ctx pointer! */
|
||||||
|
while (tal_first(NULL))
|
||||||
|
tal_free(tal_first(NULL));
|
||||||
|
exit(0);
|
||||||
|
}
|
Loading…
Reference in New Issue
Block a user