Browse Source

wallet: Cleanup db files if the tests succeed

Signed-off-by: Christian Decker <decker.christian@gmail.com>
ppa-0.6.1
Christian Decker 7 years ago
committed by Rusty Russell
parent
commit
d43403257d
  1. 54
      wallet/test/run-wallet.c

54
wallet/test/run-wallet.c

@ -490,9 +490,16 @@ static void mempat(void *dst, size_t len)
p[i] = n % 251; /* Prime */ p[i] = n % 251; /* Prime */
} }
/* Destructor for the wallet which unlinks the underlying file */
static void cleanup_test_wallet(struct wallet *w, char *filename)
{
unlink(filename);
tal_free(filename);
}
static struct wallet *create_test_wallet(struct lightningd *ld, const tal_t *ctx) static struct wallet *create_test_wallet(struct lightningd *ld, const tal_t *ctx)
{ {
char filename[] = "/tmp/ldb-XXXXXX"; char *filename = tal_fmt(ctx, "/tmp/ldb-XXXXXX");
int fd = mkstemp(filename); int fd = mkstemp(filename);
struct wallet *w = tal(ctx, struct wallet); struct wallet *w = tal(ctx, struct wallet);
static unsigned char badseed[BIP32_ENTROPY_LEN_128]; static unsigned char badseed[BIP32_ENTROPY_LEN_128];
@ -500,6 +507,7 @@ static struct wallet *create_test_wallet(struct lightningd *ld, const tal_t *ctx
close(fd); close(fd);
w->db = db_open(w, filename); w->db = db_open(w, filename);
tal_add_destructor2(w, cleanup_test_wallet, filename);
list_head_init(&w->unstored_payments); list_head_init(&w->unstored_payments);
w->ld = ld; w->ld = ld;
@ -518,23 +526,14 @@ static struct wallet *create_test_wallet(struct lightningd *ld, const tal_t *ctx
return w; return w;
} }
static bool test_wallet_outputs(void) static bool test_wallet_outputs(struct lightningd *ld, const tal_t *ctx)
{ {
char filename[] = "/tmp/ldb-XXXXXX"; struct wallet *w = create_test_wallet(ld, ctx);
struct utxo u; struct utxo u;
int fd = mkstemp(filename);
CHECK_MSG(fd != -1, "Unable to generate temp filename");
close(fd);
struct wallet *w = tal(NULL, struct wallet);
struct pubkey pk; struct pubkey pk;
u64 fee_estimate, change_satoshis; u64 fee_estimate, change_satoshis;
const struct utxo **utxos; const struct utxo **utxos;
CHECK(w);
w->db = db_open(w, filename);
CHECK_MSG(w->db, "Failed opening the db");
db_migrate(w->db, NULL);
CHECK_MSG(!wallet_err, "DB migration failed");
memset(&u, 0, sizeof(u)); memset(&u, 0, sizeof(u));
u.amount = 1; u.amount = 1;
@ -596,33 +595,20 @@ static bool test_wallet_outputs(void)
"could not change output state ignoring oldstate"); "could not change output state ignoring oldstate");
db_commit_transaction(w->db); db_commit_transaction(w->db);
tal_free(w);
return true; return true;
} }
static bool test_shachain_crud(void) static bool test_shachain_crud(struct lightningd *ld, const tal_t *ctx)
{ {
struct wallet_shachain a, b; struct wallet_shachain a, b;
char filename[] = "/tmp/ldb-XXXXXX"; struct wallet *w = create_test_wallet(ld, ctx);
int fd = mkstemp(filename);
struct wallet *w = tal(NULL, struct wallet);
struct sha256 seed, hash; struct sha256 seed, hash;
uint64_t index = UINT64_MAX >> (64 - SHACHAIN_BITS); uint64_t index = UINT64_MAX >> (64 - SHACHAIN_BITS);
w->db = db_open(w, filename);
CHECK_MSG(w->db, "Failed opening the db");
db_migrate(w->db, NULL);
CHECK_MSG(!wallet_err, "DB migration failed");
CHECK_MSG(fd != -1, "Unable to generate temp filename");
close(fd);
memset(&seed, 'A', sizeof(seed)); memset(&seed, 'A', sizeof(seed));
memset(&a, 0, sizeof(a)); memset(&a, 0, sizeof(a));
memset(&b, 0, sizeof(b)); memset(&b, 0, sizeof(b));
w->db = db_open(w, filename);
db_begin_transaction(w->db); db_begin_transaction(w->db);
CHECK_MSG(!wallet_err, "db_begin_transaction failed"); CHECK_MSG(!wallet_err, "db_begin_transaction failed");
wallet_shachain_init(w, &a); wallet_shachain_init(w, &a);
@ -644,7 +630,6 @@ static bool test_shachain_crud(void)
db_commit_transaction(w->db); db_commit_transaction(w->db);
CHECK(!wallet_err); CHECK(!wallet_err);
tal_free(w);
return true; return true;
} }
@ -831,7 +816,6 @@ static bool test_channel_crud(struct lightningd *ld, const tal_t *ctx)
db_commit_transaction(w->db); db_commit_transaction(w->db);
CHECK(!wallet_err); CHECK(!wallet_err);
tal_free(w);
/* Normally freed by destroy_channel, but we don't call that */ /* Normally freed by destroy_channel, but we don't call that */
tal_free(p); tal_free(p);
return true; return true;
@ -1010,15 +994,19 @@ int main(void)
htlc_in_map_init(&ld->htlcs_in); htlc_in_map_init(&ld->htlcs_in);
htlc_out_map_init(&ld->htlcs_out); htlc_out_map_init(&ld->htlcs_out);
ok &= test_wallet_outputs(); ok &= test_wallet_outputs(ld, tmpctx);
ok &= test_shachain_crud(); ok &= test_shachain_crud(ld, tmpctx);
ok &= test_channel_crud(ld, tmpctx); ok &= test_channel_crud(ld, tmpctx);
ok &= test_channel_config_crud(ld, tmpctx); ok &= test_channel_config_crud(ld, tmpctx);
ok &= test_htlc_crud(ld, tmpctx); ok &= test_htlc_crud(ld, tmpctx);
ok &= test_payment_crud(ld, tmpctx); ok &= test_payment_crud(ld, tmpctx);
take_cleanup(); /* Do not clean up in the case of an error, we might want to debug the
* database. */
if (ok) {
tal_free(tmpctx); tal_free(tmpctx);
take_cleanup();
}
wally_cleanup(0); wally_cleanup(0);
return !ok; return !ok;
} }

Loading…
Cancel
Save