diff options
author | joey <joey@0fa5a96a-9a0e-0410-b3b2-a0fd24251071> | 2007-04-27 02:55:52 +0000 |
---|---|---|
committer | joey <joey@0fa5a96a-9a0e-0410-b3b2-a0fd24251071> | 2007-04-27 02:55:52 +0000 |
commit | ee1ad53c4c2710aa7ded61bdc56f3a8cce514f22 (patch) | |
tree | 85914bbbf7ac596f0fc001071c91f4e31db0b49e /t | |
parent | 80aa0336e692ba9c63cb934d91bf5f1962507700 (diff) | |
download | ikiwiki-ee1ad53c4c2710aa7ded61bdc56f3a8cce514f22.tar ikiwiki-ee1ad53c4c2710aa7ded61bdc56f3a8cce514f22.tar.gz |
* pagespec_match() has changed to take named parameters, to better allow
for extended pagespecs. The old calling convention will still work for
back-compat for now.
* The calling convention for functions in the IkiWiki::PageSpec namespace
has changed so they are passed named parameters.
* Plugin interface version increased to 2.00 since I don't anticipate any
more interface changes before 2.0.
Diffstat (limited to 't')
-rwxr-xr-x | t/pagespec_match.t | 60 |
1 files changed, 32 insertions, 28 deletions
diff --git a/t/pagespec_match.t b/t/pagespec_match.t index 09e9582d1..eac2395ed 100755 --- a/t/pagespec_match.t +++ b/t/pagespec_match.t @@ -1,29 +1,30 @@ #!/usr/bin/perl use warnings; use strict; -use Test::More tests => 46; +use Test::More tests => 49; BEGIN { use_ok("IkiWiki"); } -ok(pagespec_match("foo", "*", "")); -ok(pagespec_match("page", "?ag?", "")); -ok(! pagespec_match("page", "?a?g?", "")); -ok(pagespec_match("foo.png", "*.*", "")); -ok(! pagespec_match("foo", "*.*", "")); -ok(pagespec_match("foo", "foo or bar", ""), "simple list"); -ok(pagespec_match("bar", "foo or bar", ""), "simple list 2"); -ok(pagespec_match("foo", "f?? and !foz", "")); -ok(! pagespec_match("foo", "f?? and !foo", "")); -ok(! pagespec_match("foo", "* and !foo", "")); -ok(! pagespec_match("foo", "foo and !foo", "")); -ok(! pagespec_match("foo.png", "* and !*.*", "")); -ok(pagespec_match("foo", "(bar or ((meep and foo) or (baz or foo) or beep))", "")); -ok(! pagespec_match("a/foo", "foo", "a/b"), "nonrelative fail"); -ok(! pagespec_match("foo", "./*", "a/b"), "relative fail"); -ok(pagespec_match("a/foo", "./*", "a/b"), "relative"); -ok(pagespec_match("a/b/foo", "./*", "a/b"), "relative 2"); -ok(pagespec_match("foo", "./*", "a"), "relative toplevel"); -ok(pagespec_match("foo/bar", "*", "baz"), "absolute"); +ok(pagespec_match("foo", "*")); +ok(pagespec_match("page", "?ag?")); +ok(! pagespec_match("page", "?a?g?")); +ok(pagespec_match("foo.png", "*.*")); +ok(! pagespec_match("foo", "*.*")); +ok(pagespec_match("foo", "foo or bar"), "simple list"); +ok(pagespec_match("bar", "foo or bar"), "simple list 2"); +ok(pagespec_match("foo", "f?? and !foz")); +ok(! pagespec_match("foo", "f?? and !foo")); +ok(! pagespec_match("foo", "* and !foo")); +ok(! pagespec_match("foo", "foo and !foo")); +ok(! pagespec_match("foo.png", "* and !*.*")); +ok(pagespec_match("foo", "(bar or ((meep and foo) or (baz or foo) or beep))")); +ok(! pagespec_match("a/foo", "foo", location => "a/b"), "nonrelative fail"); +ok(! pagespec_match("foo", "./*", location => "a/b"), "relative fail"); +ok(pagespec_match("a/foo", "./*", location => "a/b"), "relative"); +ok(pagespec_match("a/b/foo", "./*", location => "a/b"), "relative 2"); +ok(pagespec_match("a/foo", "./*", "a/b"), "relative oldstyle call"); +ok(pagespec_match("foo", "./*", location => "a"), "relative toplevel"); +ok(pagespec_match("foo/bar", "*", location => "baz"), "absolute"); # The link and backlink stuff needs this. $config{userdir}=""; @@ -37,16 +38,16 @@ $links{"done"}=[]; $links{"examples/softwaresite/bugs/fails_to_frobnicate"}=[qw{done}]; $links{"examples/softwaresite/bugs/done"}=[]; -ok(pagespec_match("foo", "link(bar)", ""), "link"); -ok(! pagespec_match("foo", "link(quux)", ""), "failed link"); -ok(pagespec_match("bugs/foo", "link(done)", "bugs/done"), "link match to bestlink"); +ok(pagespec_match("foo", "link(bar)"), "link"); +ok(! pagespec_match("foo", "link(quux)"), "failed link"); +ok(pagespec_match("bugs/foo", "link(done)", location => "bugs/done"), "link match to bestlink"); ok(! pagespec_match("examples/softwaresite/bugs/done", "link(done)", - "bugs/done"), "link match to bestlink"); + location => "bugs/done"), "link match to bestlink"); ok(pagespec_match("examples/softwaresite/bugs/fails_to_frobnicate", - "link(./done)", "examples/softwaresite/bugs/done"), "link relative"); -ok(! pagespec_match("foo", "link(./bar)", "foo/bar"), "link relative fail"); -ok(pagespec_match("bar", "backlink(foo)", ""), "backlink"); -ok(! pagespec_match("quux", "backlink(foo)", ""), "failed backlink"); + "link(./done)", location => "examples/softwaresite/bugs/done"), "link relative"); +ok(! pagespec_match("foo", "link(./bar)", location => "foo/bar"), "link relative fail"); +ok(pagespec_match("bar", "backlink(foo)"), "backlink"); +ok(! pagespec_match("quux", "backlink(foo)"), "failed backlink"); $IkiWiki::pagectime{foo}=1154532692; # Wed Aug 2 11:26 EDT 2006 $IkiWiki::pagectime{bar}=1154532695; # after @@ -63,6 +64,9 @@ ok(! pagespec_match("foo", "creation_day(3)"), "other day"); ok(! pagespec_match("foo", "no_such_function(foo)"), "foo"); +ok(pagespec_match("foo", "foo and user(bar)", user => "bar"), "user"); +ok(! pagespec_match("foo", "foo and user(bar)", user => "baz"), "user fail"); + # old style globlists ok(pagespec_match("foo", "foo bar"), "simple list"); ok(pagespec_match("bar", "foo bar"), "simple list 2"); |