Browse Source
parse_address_line had not the same behavior whether the user had Mail::Address or not. Teach parse_address_line to behave like Mail::Address. When the user input is correct, this implementation behaves exactly like Mail::Address except when there are quotes inside the name: "Jane Do"e <jdoe@example.com> In this case the result of parse_address_line is: With M::A : "Jane Do" e <jdoe@example.com> Without : "Jane Do e" <jdoe@example.com> When the user input is not correct, the behavior is also mostly the same. Unlike Mail::Address, this doesn't parse groups and recursive commentaries. Signed-off-by: Remi Lespinet <remi.lespinet@ensimag.grenoble-inp.fr> Signed-off-by: Matthieu Moy <Matthieu.Moy@imag.fr> Signed-off-by: Junio C Hamano <gitster@pobox.com>maint
Remi Lespinet
10 years ago
committed by
Junio C Hamano
4 changed files with 162 additions and 1 deletions
@ -0,0 +1,27 @@
@@ -0,0 +1,27 @@
|
||||
#!/bin/sh |
||||
|
||||
test_description='compare address parsing with and without Mail::Address' |
||||
. ./test-lib.sh |
||||
|
||||
if ! test_have_prereq PERL; then |
||||
skip_all='skipping perl interface tests, perl not available' |
||||
test_done |
||||
fi |
||||
|
||||
perl -MTest::More -e 0 2>/dev/null || { |
||||
skip_all="Perl Test::More unavailable, skipping test" |
||||
test_done |
||||
} |
||||
|
||||
perl -MMail::Address -e 0 2>/dev/null || { |
||||
skip_all="Perl Mail::Address unavailable, skipping test" |
||||
test_done |
||||
} |
||||
|
||||
test_external_has_tap=1 |
||||
|
||||
test_external_without_stderr \ |
||||
'Perl address parsing function' \ |
||||
perl "$TEST_DIRECTORY"/t9000/test.pl |
||||
|
||||
test_done |
@ -0,0 +1,67 @@
@@ -0,0 +1,67 @@
|
||||
#!/usr/bin/perl |
||||
use lib (split(/:/, $ENV{GITPERLLIB})); |
||||
|
||||
use 5.008; |
||||
use warnings; |
||||
use strict; |
||||
|
||||
use Test::More qw(no_plan); |
||||
use Mail::Address; |
||||
|
||||
BEGIN { use_ok('Git') } |
||||
|
||||
my @success_list = (q[Jane], |
||||
q[jdoe@example.com], |
||||
q[<jdoe@example.com>], |
||||
q[Jane <jdoe@example.com>], |
||||
q[Jane Doe <jdoe@example.com>], |
||||
q["Jane" <jdoe@example.com>], |
||||
q["Doe, Jane" <jdoe@example.com>], |
||||
q["Jane@:;\>.,()<Doe" <jdoe@example.com>], |
||||
q[Jane!#$%&'*+-/=?^_{|}~Doe' <jdoe@example.com>], |
||||
q["<jdoe@example.com>"], |
||||
q["Jane jdoe@example.com"], |
||||
q[Jane Doe <jdoe @ example.com >], |
||||
q[Jane Doe < jdoe@example.com >], |
||||
q[Jane @ Doe @ Jane @ Doe], |
||||
q["Jane, 'Doe'" <jdoe@example.com>], |
||||
q['Doe, "Jane' <jdoe@example.com>], |
||||
q["Jane" "Do"e <jdoe@example.com>], |
||||
q["Jane' Doe" <jdoe@example.com>], |
||||
q["Jane Doe <jdoe@example.com>" <jdoe@example.com>], |
||||
q["Jane\" Doe" <jdoe@example.com>], |
||||
q[Doe, jane <jdoe@example.com>], |
||||
q["Jane Doe <jdoe@example.com>], |
||||
q['Jane 'Doe' <jdoe@example.com>]); |
||||
|
||||
my @known_failure_list = (q[Jane\ Doe <jdoe@example.com>], |
||||
q["Doe, Ja"ne <jdoe@example.com>], |
||||
q["Doe, Katarina" Jane <jdoe@example.com>], |
||||
q[Jane@:;\.,()<>Doe <jdoe@example.com>], |
||||
q[Jane jdoe@example.com], |
||||
q[<jdoe@example.com> Jane Doe], |
||||
q[Jane <jdoe@example.com> Doe], |
||||
q["Jane "Kat"a" ri"na" ",Doe" <jdoe@example.com>], |
||||
q[Jane Doe], |
||||
q[Jane "Doe <jdoe@example.com>"], |
||||
q[\"Jane Doe <jdoe@example.com>], |
||||
q[Jane\"\" Doe <jdoe@example.com>], |
||||
q['Jane "Katarina\" \' Doe' <jdoe@example.com>]); |
||||
|
||||
foreach my $str (@success_list) { |
||||
my @expected = map { $_->format } Mail::Address->parse("$str"); |
||||
my @actual = Git::parse_mailboxes("$str"); |
||||
is_deeply(\@expected, \@actual, qq[same output : $str]); |
||||
} |
||||
|
||||
TODO: { |
||||
local $TODO = "known breakage"; |
||||
foreach my $str (@known_failure_list) { |
||||
my @expected = map { $_->format } Mail::Address->parse("$str"); |
||||
my @actual = Git::parse_mailboxes("$str"); |
||||
is_deeply(\@expected, \@actual, qq[same output : $str]); |
||||
} |
||||
} |
||||
|
||||
my $is_passing = eval { Test::More->is_passing }; |
||||
exit($is_passing ? 0 : 1) unless $@ =~ /Can't locate object method/; |
Loading…
Reference in new issue