]> git.vanrenterghem.biz Git - git.ikiwiki.info.git/blobdiff - t/linkify.t
bug fix; now checks extensions.
[git.ikiwiki.info.git] / t / linkify.t
index 0510cd6dbb24c2acaa9f2e8dab82a0d9c50adfb1..6dff0a02954a7c61b5d05fc79a994d1486d2e005 100755 (executable)
@@ -5,6 +5,10 @@ use Test::More tests => 32;
 
 BEGIN { use_ok("IkiWiki"); }
 
 
 BEGIN { use_ok("IkiWiki"); }
 
+# Initialize link plugin
+%config=IkiWiki::defaultconfig();
+IkiWiki::loadplugins();
+
 my $prefix_directives;
 
 sub linkify ($$$$) {
 my $prefix_directives;
 
 sub linkify ($$$$) {
@@ -18,11 +22,11 @@ sub linkify ($$$$) {
        # This could change, if so, update it..
        %IkiWiki::pagecase=();
        %links=();
        # This could change, if so, update it..
        %IkiWiki::pagecase=();
        %links=();
-       foreach my $page (@existing_pages) {
-               $IkiWiki::pagecase{lc $page}=$page;
-               $links{$page}=[];
-               $renderedfiles{"$page.mdwn"}=[$page];
-               $destsources{$page}="$page.mdwn";
+       foreach my $p (@existing_pages) {
+               $IkiWiki::pagecase{lc $p}=$p;
+               $links{$p}=[];
+               $renderedfiles{"$p.mdwn"}=[$p];
+               $destsources{$p}="$p.mdwn";
        }
 
        %config=IkiWiki::defaultconfig();
        }
 
        %config=IkiWiki::defaultconfig();
@@ -41,7 +45,7 @@ sub links_to ($$) {
        my $link=shift;
        my $content=shift;
        
        my $link=shift;
        my $content=shift;
        
-       if ($content =~ m!<a href="[^"]*\Q$link\E[^"]*">!) {
+       if ($content =~ m!<a href="[^"]*\Q$link\E[^"]*"\s*[^>]*>!) {
                return 1;
        }
        else {
                return 1;
        }
        else {
@@ -89,8 +93,8 @@ foreach $prefix_directives (0,1) {
        ok(links_text("0", linkify("foo", "foo", "link to [[0|bar]] ok", ["foo", "bar"])), "named link to 0");
        ok(links_text("Some long, & complex page name.", linkify("foo", "foo", "link to [[Some_long,_&_complex_page_name.|bar]] ok, and this is not a link]] here", ["foo", "bar"])), "complex named link text");
        ok(links_to("foo/bar", linkify("foo/item", "foo", "link to [[bar]] ok", ["foo", "foo/item", "foo/bar"])), "inline page link");
        ok(links_text("0", linkify("foo", "foo", "link to [[0|bar]] ok", ["foo", "bar"])), "named link to 0");
        ok(links_text("Some long, & complex page name.", linkify("foo", "foo", "link to [[Some_long,_&_complex_page_name.|bar]] ok, and this is not a link]] here", ["foo", "bar"])), "complex named link text");
        ok(links_to("foo/bar", linkify("foo/item", "foo", "link to [[bar]] ok", ["foo", "foo/item", "foo/bar"])), "inline page link");
-       ok(links_to("bar", linkify("foo", "foo", "link to [[bar]] ok", ["foo", "foo/item", "foo/bar"])), "same except not inline");
-       ok(links_to("bar#baz", linkify("foo", "foo", "link to [[bar#baz]] ok", ["foo", "bar"])), "anchor link");
+       ok(links_to("bar",     linkify("foo",      "foo", "link to [[bar]] ok", ["foo", "foo/item", "foo/bar"])), "same except not inline");
+       ok(links_to("bar#baz", linkify("foo",      "foo", "link to [[bar#baz]] ok", ["foo", "bar"])), "anchor link");
 }
 
 $prefix_directives=0;
 }
 
 $prefix_directives=0;