From 8d314d7afec5adaaa8e22332e39fe84a39584653 Mon Sep 17 00:00:00 2001 From: Remi Lespinet Date: Tue, 7 Jul 2015 15:38:15 +0200 Subject: send-email: reduce dependencies impact on parse_address_line 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 In this case the result of parse_address_line is: With M::A : "Jane Do" e Without : "Jane Do e" 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 Signed-off-by: Matthieu Moy Signed-off-by: Junio C Hamano --- t/t9000/test.pl | 67 +++++++++++++++++++++++++++++++++++++++++++++++++++++++++ 1 file changed, 67 insertions(+) create mode 100755 t/t9000/test.pl (limited to 't/t9000') diff --git a/t/t9000/test.pl b/t/t9000/test.pl new file mode 100755 index 0000000000..2d05d3eeab --- /dev/null +++ b/t/t9000/test.pl @@ -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[], + q[Jane ], + q[Jane Doe ], + q["Jane" ], + q["Doe, Jane" ], + q["Jane@:;\>.,()], + q[Jane!#$%&'*+-/=?^_{|}~Doe' ], + q[""], + q["Jane jdoe@example.com"], + q[Jane Doe ], + q[Jane Doe < jdoe@example.com >], + q[Jane @ Doe @ Jane @ Doe], + q["Jane, 'Doe'" ], + q['Doe, "Jane' ], + q["Jane" "Do"e ], + q["Jane' Doe" ], + q["Jane Doe " ], + q["Jane\" Doe" ], + q[Doe, jane ], + q["Jane Doe ], + q['Jane 'Doe' ]); + +my @known_failure_list = (q[Jane\ Doe ], + q["Doe, Ja"ne ], + q["Doe, Katarina" Jane ], + q[Jane@:;\.,()<>Doe ], + q[Jane jdoe@example.com], + q[ Jane Doe], + q[Jane Doe], + q["Jane "Kat"a" ri"na" ",Doe" ], + q[Jane Doe], + q[Jane "Doe "], + q[\"Jane Doe ], + q[Jane\"\" Doe ], + q['Jane "Katarina\" \' Doe' ]); + +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/; -- cgit v1.2.3