X-Git-Url: http://www.git.stargrave.org/?a=blobdiff_plain;f=t%2Flinkify.t;h=9280fd91fcf70f5a3306ac14dc5d6de3b4c896c1;hb=fbe89926961e2e090481fa283048c31aaddc17cf;hp=f0b3a6d0b34bdb438a0fc940a9bbb3da2bbce87b;hpb=58700fb1830d1f854e688dfa47390d7f2eef9035;p=public-inbox.git
diff --git a/t/linkify.t b/t/linkify.t
index f0b3a6d0..9280fd91 100644
--- a/t/linkify.t
+++ b/t/linkify.t
@@ -1,4 +1,4 @@
-# Copyright (C) 2016-2018 all contributors
+# Copyright (C) 2016-2021 all contributors
# License: AGPL-3.0+
use strict;
use warnings;
@@ -50,6 +50,11 @@ use PublicInbox::Linkify;
$s = $l->linkify_2($s);
is($s, qq(hello $u world), 'URL preserved');
+ $s = "$u. hi";
+ $s = $l->linkify_1($s);
+ $s = $l->linkify_2($s);
+ is($s, qq($u. hi), 'paired () in URL OK');
+
$u .= "?query=a";
$s = "hello $u world";
$s = $l->linkify_1($s);
@@ -98,4 +103,50 @@ use PublicInbox::Linkify;
'Markdown-compatible end of sentence');
}
+# Perl and Ruby code compatibility
+{
+ my $l = PublicInbox::Linkify->new;
+ my $u = 'http://example.com/';
+ foreach my $q ("'%s'", '"%s"', 'q!%s!', 'q(%s)') {
+ # Perl
+ my $s = sprintf("my \$var = $q;", $u);
+ $s = $l->linkify_1($s);
+ $s = $l->linkify_2($s);
+ like($s, qr/>\Q$u\E, "no quote($q) in URL");
+
+ # applies to Ruby, too
+ $s = sprintf("$q,", $u);
+ $s = $l->linkify_1($s);
+ $s = $l->linkify_2($s);
+ like($s, qr/>\Q$u\E, "no quote($q) in URL array");
+ }
+}
+
+# dangling ')' cf. see MaintNotes in git.git todo branch
+{
+ my $l = PublicInbox::Linkify->new;
+ my $s = '(see http://example.com/).';
+ $s = $l->linkify_1($s);
+ $s = $l->linkify_2($s);
+ like($s, qr!\(see ]+>http://example\.com/\)\.!s,
+ 'punctuation with unpaired ) OK')
+}
+
+if ('IDN example: ') {
+ my $hc = '月';
+ my $u = "http://www.\x{6708}.example.com/";
+ my $s = $u;
+ my $l = PublicInbox::Linkify->new;
+ $s = $l->linkify_1($s);
+ $s = $l->linkify_2($s);
+ my $expect = qq{http://www.$hc.example.com/};
+ is($s, $expect, 'IDN message escaped properly');
+}
+
+{
+ my $false_positive = 'LINKIFY'.('A' x 40);
+ is(PublicInbox::Linkify->new->to_html($false_positive),
+ $false_positive, 'false-positive left as-is');
+}
done_testing();