X-Git-Url: http://git.vanrenterghem.biz/git.ikiwiki.info.git/blobdiff_plain/955bcea2a7bacb98cb62a38faa78b05e0f430aac..8f4f81cdfdcb68be5efb385dc07e4a0a04352a9d:/t/pagespec_match.t diff --git a/t/pagespec_match.t b/t/pagespec_match.t index ab3fcdd4b..8b0be4e8a 100755 --- a/t/pagespec_match.t +++ b/t/pagespec_match.t @@ -1,7 +1,7 @@ #!/usr/bin/perl use warnings; use strict; -use Test::More tests => 64; +use Test::More tests => 72; BEGIN { use_ok("IkiWiki"); } @@ -40,6 +40,15 @@ ok(! pagespec_match("foo", "foo and bar"), "foo and bar"); ok(pagespec_match("{f}oo", "{*}*"), "curly match"); ok(! pagespec_match("foo", "{*}*"), "curly !match"); +ok(pagespec_match("somepage", "user(frodo)", user => "frodo")); +ok(pagespec_match("somepage", "user(frodo)", user => "Frodo")); +ok(! pagespec_match("somepage", "user(frodo)", user => "Sam")); +ok(pagespec_match("somepage", "user(*o)", user => "Bilbo")); +ok(pagespec_match("somepage", "user(*o)", user => "frodo")); +ok(! pagespec_match("somepage", "user(*o)", user => "Sam")); +ok(pagespec_match("somepage", "user(http://*.myopenid.com/)", user => "http://foo.myopenid.com/")); +ok(pagespec_match("somepage", "user(*://*)", user => "http://foo.myopenid.com/")); + # The link and backlink stuff needs this. $config{userdir}=""; $links{foo}=[qw{bar baz}]; @@ -49,9 +58,13 @@ $links{"bugs/foo"}=[qw{bugs/done}]; $links{"bugs/done"}=[]; $links{"bugs/bar"}=[qw{done}]; $links{"done"}=[]; +$links{"done"}=[]; $links{"examples/softwaresite/bugs/fails_to_frobnicate"}=[qw{done}]; $links{"examples/softwaresite/bugs/done"}=[]; $links{"ook"}=[qw{/blog/tags/foo}]; +foreach my $p (keys %links) { + $pagesources{$p}="$p.mdwn"; +} ok(pagespec_match("foo", "link(bar)"), "link"); ok(pagespec_match("foo", "link(ba?)"), "glob link"); @@ -93,19 +106,19 @@ $ret=pagespec_match("foo", "bar or foo"); ok($ret, "simple match"); is($ret, "foo matches foo", "stringified return"); -my %i=pagespec_match("foo", "link(bar)")->influences; -is(join(",", keys %i), 'foo', "link is influenced by the page with the link"); -%i=pagespec_match("bar", "backlink(foo)")->influences; -is(join(",", keys %i), 'foo', "backlink is influenced by the page with the link"); -%i=pagespec_match("bar", "backlink(foo)")->influences; -is(join(",", keys %i), 'foo', "backlink is influenced by the page with the link"); -%i=pagespec_match("bar", "created_before(foo)")->influences; -is(join(",", keys %i), 'foo', "created_before is influenced by the comparison page"); -%i=pagespec_match("bar", "created_after(foo)")->influences; -is(join(",", keys %i), 'foo', "created_after is influenced by the comparison page"); -%i=pagespec_match("foo", "link(baz) and created_after(bar)")->influences; -is(join(",", sort keys %i), 'bar,foo', "influences add up over AND"); -%i=pagespec_match("foo", "link(baz) and created_after(bar)")->influences; -is(join(",", sort keys %i), 'bar,foo', "influences add up over OR"); -%i=pagespec_match("foo", "!link(baz) and !created_after(bar)")->influences; -is(join(",", sort keys %i), 'bar,foo', "influences unaffected by negation"); +my $i=pagespec_match("foo", "link(bar)")->influences; +is(join(",", keys %$i), 'foo', "link is influenced by the page with the link"); +$i=pagespec_match("bar", "backlink(foo)")->influences; +is(join(",", keys %$i), 'foo', "backlink is influenced by the page with the link"); +$i=pagespec_match("bar", "backlink(foo)")->influences; +is(join(",", keys %$i), 'foo', "backlink is influenced by the page with the link"); +$i=pagespec_match("bar", "created_before(foo)")->influences; +is(join(",", keys %$i), 'foo', "created_before is influenced by the comparison page"); +$i=pagespec_match("bar", "created_after(foo)")->influences; +is(join(",", keys %$i), 'foo', "created_after is influenced by the comparison page"); +$i=pagespec_match("foo", "link(baz) and created_after(bar)")->influences; +is(join(",", sort keys %$i), 'bar,foo', "influences add up over AND"); +$i=pagespec_match("foo", "link(baz) and created_after(bar)")->influences; +is(join(",", sort keys %$i), 'bar,foo', "influences add up over OR"); +$i=pagespec_match("foo", "!link(baz) and !created_after(bar)")->influences; +is(join(",", sort keys %$i), 'bar,foo', "influences unaffected by negation");