diff options
author | Eric Wong <e@yhbt.net> | 2020-06-27 10:03:35 +0000 |
---|---|---|
committer | Eric Wong <e@yhbt.net> | 2020-06-28 22:27:13 +0000 |
commit | 5808636263d72b635a46100a7e7037074dad8f75 (patch) | |
tree | 350156684882124b7ce684e2201ce3db2febf5d0 /t | |
parent | 1d2cc9c8ebf7916616c947837854a4a01d76d447 (diff) | |
download | public-inbox-5808636263d72b635a46100a7e7037074dad8f75.tar.gz |
We need to detect link(2) and rename(2) in other apps writing to the Maildir. We'll be removing the Filesys::Notify::Simple from -watch in favor of using IO::KQueue or Linux::Inotify2 directly. Ensure non-inotify emulations can support everything we expect for Maildir writers.
Diffstat (limited to 't')
-rw-r--r-- | t/fake_inotify.t | 45 | ||||
-rw-r--r-- | t/kqnotify.t | 41 |
2 files changed, 86 insertions, 0 deletions
diff --git a/t/fake_inotify.t b/t/fake_inotify.t new file mode 100644 index 00000000..f0db0cb5 --- /dev/null +++ b/t/fake_inotify.t @@ -0,0 +1,45 @@ +#!perl -w +# Copyright (C) 2020 all contributors <meta@public-inbox.org> +# License: AGPL-3.0+ <https://www.gnu.org/licenses/agpl-3.0.txt> +# +# Ensure FakeInotify can pick up rename(2) and link(2) operations +# used by Maildir writing tools +use strict; +use Test::More; +use PublicInbox::TestCommon; +use_ok 'PublicInbox::FakeInotify'; +my $MIN_FS_TICK = 0.011; # for low-res CONFIG_HZ=100 systems +my ($tmpdir, $for_destroy) = tmpdir(); +mkdir "$tmpdir/new" or BAIL_OUT "mkdir: $!"; +open my $fh, '>', "$tmpdir/tst" or BAIL_OUT "open: $!"; +close $fh or BAIL_OUT "close: $!"; + +my $fi = PublicInbox::FakeInotify->new; +my $mask = PublicInbox::FakeInotify::MOVED_TO_OR_CREATE(); +my $hit = []; +my $cb = sub { push @$hit, map { $_->fullname } @_ }; +my $w = $fi->watch("$tmpdir/new", $mask, $cb); + +select undef, undef, undef, $MIN_FS_TICK; +rename("$tmpdir/tst", "$tmpdir/new/tst") or BAIL_OUT "rename: $!"; +$fi->poll; +is_deeply($hit, ["$tmpdir/new/tst"], 'rename(2) detected'); + +@$hit = (); +select undef, undef, undef, $MIN_FS_TICK; +open $fh, '>', "$tmpdir/tst" or BAIL_OUT "open: $!"; +close $fh or BAIL_OUT "close: $!"; +link("$tmpdir/tst", "$tmpdir/new/link") or BAIL_OUT "link: $!"; +$fi->poll; +is_deeply($hit, ["$tmpdir/new/link"], 'link(2) detected'); + +$w->cancel; +@$hit = (); +select undef, undef, undef, $MIN_FS_TICK; +link("$tmpdir/new/tst", "$tmpdir/new/link2") or BAIL_OUT "link: $!"; +$fi->poll; +is_deeply($hit, [], 'link(2) not detected after cancel'); + +PublicInbox::DS->Reset; + +done_testing; diff --git a/t/kqnotify.t b/t/kqnotify.t new file mode 100644 index 00000000..b3414b8a --- /dev/null +++ b/t/kqnotify.t @@ -0,0 +1,41 @@ +#!perl -w +# Copyright (C) 2020 all contributors <meta@public-inbox.org> +# License: AGPL-3.0+ <https://www.gnu.org/licenses/agpl-3.0.txt> +# +# Ensure KQNotify can pick up rename(2) and link(2) operations +# used by Maildir writing tools +use strict; +use Test::More; +use PublicInbox::TestCommon; +plan skip_all => 'KQNotify is only for *BSD systems' if $^O !~ /bsd/; +require_mods('IO::KQueue'); +use_ok 'PublicInbox::KQNotify'; +my ($tmpdir, $for_destroy) = tmpdir(); +mkdir "$tmpdir/new" or BAIL_OUT "mkdir: $!"; +open my $fh, '>', "$tmpdir/tst" or BAIL_OUT "open: $!"; +close $fh or BAIL_OUT "close: $!"; + +my $kqn = PublicInbox::KQNotify->new; +my $mask = PublicInbox::KQNotify::MOVED_TO_OR_CREATE(); +my $hit = []; +my $cb = sub { push @$hit, map { $_->fullname } @_ }; +my $w = $kqn->watch("$tmpdir/new", $mask, $cb); + +rename("$tmpdir/tst", "$tmpdir/new/tst") or BAIL_OUT "rename: $!"; +$kqn->poll; +is_deeply($hit, ["$tmpdir/new/tst"], 'rename(2) detected (via NOTE_EXTEND)'); + +@$hit = (); +open $fh, '>', "$tmpdir/tst" or BAIL_OUT "open: $!"; +close $fh or BAIL_OUT "close: $!"; +link("$tmpdir/tst", "$tmpdir/new/link") or BAIL_OUT "link: $!"; +$kqn->poll; +is_deeply($hit, ["$tmpdir/new/link"], 'link(2) detected (via NOTE_WRITE)'); + +$w->cancel; +@$hit = (); +link("$tmpdir/new/tst", "$tmpdir/new/link2") or BAIL_OUT "link: $!"; +$kqn->poll; +is_deeply($hit, [], 'link(2) not detected after cancel'); + +done_testing; |