]> Sergey Matveev's repositories - public-inbox.git/blobdiff - t/address.t
public-inbox 1.1.0-pre1
[public-inbox.git] / t / address.t
index c488a8ed6f726ef032fe11884fd557da1df304d6..eced5c4632cdea1e86990ac7e594e61acf75c6ab 100644 (file)
@@ -1,4 +1,4 @@
-# Copyright (C) 2016 all contributors <meta@public-inbox.org>
+# Copyright (C) 2016-2018 all contributors <meta@public-inbox.org>
 # License: AGPL-3.0+ <https://www.gnu.org/licenses/agpl-3.0.txt>
 use strict;
 use warnings;
@@ -9,13 +9,29 @@ is_deeply([qw(e@example.com e@example.org)],
        [PublicInbox::Address::emails('User <e@example.com>, e@example.org')],
        'address extraction works as expected');
 
-is_deeply([PublicInbox::Address::emails('"ex@example.com" <ex@example.com>')],
-       [qw(ex@example.com)]);
+is_deeply(['user@example.com'],
+       [PublicInbox::Address::emails('<user@example.com (Comment)>')],
+       'comment after domain accepted before >');
 
 my @names = PublicInbox::Address::names(
        'User <e@e>, e@e, "John A. Doe" <j@d>, <x@x>');
 is_deeply(['User', 'e', 'John A. Doe', 'x'], \@names,
        'name extraction works as expected');
 
+@names = PublicInbox::Address::names('"user@example.com" <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, ['u'], 'backwards name OK');
+       my @emails = PublicInbox::Address::emails($backwards);
+       is_deeply(\@emails, ['u@example.com'], 'backwards emails OK');
+}
+
+
+@names = PublicInbox::Address::names('"Quote Unneeded" <user@example.com>');
+is_deeply(['Quote Unneeded'], \@names, 'extra quotes dropped');
 
 done_testing;