X-Git-Url: http://www.git.stargrave.org/?a=blobdiff_plain;f=t%2Faddress.t;h=6f4bff6c42928f4707355d9c25b286f1e6dac042;hb=c29b2b7ded47def906cf00e3baad65c102304120;hp=2a2871029ba6299a6634f247b22b0f261571da7e;hpb=01d25810ec9baf643e2a278a0fefdf857bfd3883;p=public-inbox.git
diff --git a/t/address.t b/t/address.t
index 2a287102..6f4bff6c 100644
--- a/t/address.t
+++ b/t/address.t
@@ -1,38 +1,58 @@
-# Copyright (C) 2016-2019 all contributors
+# Copyright (C) 2016-2020 all contributors
# License: AGPL-3.0+
use strict;
use warnings;
use Test::More;
use_ok 'PublicInbox::Address';
-is_deeply([qw(e@example.com e@example.org)],
- [PublicInbox::Address::emails('User , e@example.org')],
- 'address extraction works as expected');
-
-is_deeply(['user@example.com'],
- [PublicInbox::Address::emails('')],
- 'comment after domain accepted before >');
-
-my @names = PublicInbox::Address::names(
- 'User , e@e, "John A. Doe" , , (xyz), '.
- 'U Ser (do not use)');
-is_deeply(\@names, ['User', 'e', 'John A. Doe', 'x', 'xyz', 'U Ser'],
- 'name extraction works as expected');
-
-@names = PublicInbox::Address::names('"user@example.com" ');
-is_deeply(['user'], \@names, 'address-as-name extraction works as expected');
-
-
-{
- my $backwards = 'u@example.com (John Q. Public)';
- @names = PublicInbox::Address::names($backwards);
- is_deeply(\@names, ['John Q. Public'], 'backwards name OK');
- my @emails = PublicInbox::Address::emails($backwards);
- is_deeply(\@emails, ['u@example.com'], 'backwards emails OK');
+sub test_pkg {
+ my ($pkg) = @_;
+ my $emails = \&{"${pkg}::emails"};
+ my $names = \&{"${pkg}::names"};
+
+ is_deeply([qw(e@example.com e@example.org)],
+ [$emails->('User , e@example.org')],
+ 'address extraction works as expected');
+
+ is_deeply(['user@example.com'],
+ [$emails->('')],
+ 'comment after domain accepted before >');
+
+ my @names = $names->(
+ 'User , e@e, "John A. Doe" , , (xyz), '.
+ 'U Ser (do not use)');
+ is_deeply(\@names, ['User', 'e', 'John A. Doe', 'x', 'xyz', 'U Ser'],
+ 'name extraction works as expected');
+
+ @names = $names->('"user@example.com" ');
+ is_deeply(['user'], \@names,
+ 'address-as-name extraction works as expected');
+
+ {
+ my $backwards = 'u@example.com (John Q. Public)';
+ @names = $names->($backwards);
+ is_deeply(\@names, ['John Q. Public'], 'backwards name OK');
+ my @emails = $emails->($backwards);
+ is_deeply(\@emails, ['u@example.com'], 'backwards emails OK');
+ }
+
+ @names = $names->('"Quote Unneeded" ');
+ is_deeply(['Quote Unneeded'], \@names, 'extra quotes dropped');
+
+ my @emails = $emails->('Local User ');
+ is_deeply([], \@emails , 'no address for local address');
+ @names = $emails->('Local User ');
+ is_deeply([], \@names, 'no address, no name');
}
+test_pkg('PublicInbox::Address');
-@names = PublicInbox::Address::names('"Quote Unneeded" ');
-is_deeply(['Quote Unneeded'], \@names, 'extra quotes dropped');
+SKIP: {
+ if ($INC{'PublicInbox/AddressPP.pm'}) {
+ skip 'Email::Address::XS missing', 8;
+ }
+ use_ok 'PublicInbox::AddressPP';
+ test_pkg('PublicInbox::AddressPP');
+}
done_testing;