From 565e905bce1e43440835dd2e4b8125b7346d6da4 Mon Sep 17 00:00:00 2001 From: Rusty Russell Date: Fri, 25 Sep 2015 11:51:19 +0930 Subject: [PATCH] test/test_state_coverage: better HTLC reporting in errors. Signed-off-by: Rusty Russell --- test/test_state_coverage.c | 41 ++++++++++++++++++++++++++++++++++++-- 1 file changed, 39 insertions(+), 2 deletions(-) diff --git a/test/test_state_coverage.c b/test/test_state_coverage.c index 223af805f..06155c311 100644 --- a/test/test_state_coverage.c +++ b/test/test_state_coverage.c @@ -1978,10 +1978,47 @@ static void report_trail(const struct trail *t) { fprintf(stderr, "Error: %s\n", t->problem); while (t) { - fprintf(stderr, "%s: %s %s -> %s\n", + size_t i; + fprintf(stderr, "%s: %s(%i) %s -> %s\n", t->name, - input_name(t->input), + input_name(t->input), t->htlc_id, state_name(t->before.state), state_name(t->after.state)); + if (t->after.state >= STATE_CLOSED) { + if (t->after.num_live_htlcs_to_us + || t->after.num_live_htlcs_to_them) { + fprintf(stderr, " Live HTLCs:"); + for (i = 0; i < t->after.num_live_htlcs_to_us; i++) + fprintf(stderr, " <%u", + t->after.live_htlcs_to_us[i].id); + for (i = 0; i < t->after.num_live_htlcs_to_them; i++) + fprintf(stderr, " >%u", + t->after.live_htlcs_to_them[i].id); + fprintf(stderr, "\n"); + } + if (t->after.num_htlc_spends_to_us + || t->after.num_htlc_spends_to_them) { + fprintf(stderr, " HTLC spends:"); + for (i = 0; i < t->after.num_htlc_spends_to_us; i++) + fprintf(stderr, " <%u", + t->after.htlc_spends_to_us[i].id); + for (i = 0; i < t->after.num_htlc_spends_to_them; i++) + fprintf(stderr, " <%u", + t->after.htlc_spends_to_them[i].id); + fprintf(stderr, "\n"); + } + } else { + if (t->after.num_htlcs_to_us + || t->after.num_htlcs_to_them) { + fprintf(stderr, " HTLCs:"); + for (i = 0; i < t->after.num_htlcs_to_us; i++) + fprintf(stderr, " <%u", + t->after.htlcs_to_us[i].id); + for (i = 0; i < t->after.num_htlcs_to_them; i++) + fprintf(stderr, " >%u", + t->after.htlcs_to_them[i].id); + fprintf(stderr, "\n"); + } + } if (t->pkt_sent) fprintf(stderr, " => %s\n", t->pkt_sent); t = t->next;