X-Git-Url: http://www.git.stargrave.org/?a=blobdiff_plain;f=t%2Fshared_kv.t;h=251b7f3942c88eceb36785f5e486fbdd4fb58cdf;hb=6248a7ab1046d0ccdc0b244099fb241fd52d653e;hp=4b72746238407c493075b94a6e899fd41aa14b0f;hpb=fa7bab31c9e5ded5c832b42de56f48dbdf9de972;p=public-inbox.git diff --git a/t/shared_kv.t b/t/shared_kv.t index 4b727462..251b7f39 100644 --- a/t/shared_kv.t +++ b/t/shared_kv.t @@ -1,17 +1,17 @@ #!perl -w -# Copyright (C) 2020 all contributors +# Copyright (C) 2020-2021 all contributors # License: AGPL-3.0+ use strict; use v5.10.1; use Test::More; use PublicInbox::TestCommon; +require_mods(qw(DBD::SQLite)); use_ok 'PublicInbox::SharedKV'; my ($tmpdir, $for_destroy) = tmpdir(); local $ENV{TMPDIR} = $tmpdir; my $skv = PublicInbox::SharedKV->new; -opendir(my $dh, $tmpdir) or BAIL_OUT $!; -my @ent = grep(!/\A\.\.?\z/, readdir($dh)); -is(scalar(@ent), 1, 'created a temporary dir'); +my $skv_tmpdir = $skv->{"tmp$$.$skv"}; +ok(-d $skv_tmpdir, 'created a temporary dir'); $skv->dbh; my $dead = "\xde\xad"; my $beef = "\xbe\xef"; @@ -26,6 +26,7 @@ is($skv->get($dead), $cafe, 'get after xchg'); is($skv->xchg($dead, undef), $cafe, 'xchg to undef'); is($skv->get($dead), undef, 'get after xchg to undef'); is($skv->get($cafe), $dead, 'get after set_maybe'); +ok($skv->index_values, 'index_values works'); is($skv->replace_values($dead, $cafe), 1, 'replaced one by value'); is($skv->get($cafe), $cafe, 'value updated'); is($skv->replace_values($dead, $cafe), 0, 'replaced none by value'); @@ -47,10 +48,7 @@ is($skv->delete_by_val($dead), 2, 'delete_by_val hits'); is($skv->delete_by_val($dead), 0, 'delete_by_val misses again'); undef $skv; -rewinddir($dh); -@ent = grep(!/\A\.\.?\z/, readdir($dh)); -is(scalar(@ent), 0, 'temporary dir gone'); -undef $dh; +ok(!-d $skv_tmpdir, 'temporary dir gone'); $skv = PublicInbox::SharedKV->new("$tmpdir/dir", 'base'); ok(-e "$tmpdir/dir/base.sqlite3", 'file created');