#!/usr/bin/perl # Copyright (C) 2004, 2005 Alex Schroeder # # This program is free software; you can redistribute it and/or modify # it under the terms of the GNU General Public License as published by # the Free Software Foundation; either version 2 of the License, or # (at your option) any later version. # # This program is distributed in the hope that it will be useful, # but WITHOUT ANY WARRANTY; without even the implied warranty of # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the # GNU General Public License for more details. # # You should have received a copy of the GNU General Public License # along with this program; if not, write to the # Free Software Foundation, Inc. # 59 Temple Place, Suite 330 # Boston, MA 02111-1307 USA # Import the functions package OddMuse; $RunCGI = 0; # don't print HTML on stdout $UseConfig = 0; # don't read module files do 'wiki.pl'; Init(); my ($passed, $failed) = (0, 0); my $resultfile = "/tmp/test-markup-result-$$"; my $redirect; undef $/; $| = 1; # no output buffering sub url_encode { my $str = shift; return '' unless $str; my @letters = split(//, $str); my @safe = ('a' .. 'z', 'A' .. 'Z', '0' .. '9', '-', '_', '.'); # shell metachars are unsafe foreach my $letter (@letters) { my $pattern = quotemeta($letter); if (not grep(/$pattern/, @safe)) { $letter = sprintf("%%%02x", ord($letter)); } } return join('', @letters); } print "* means that a page is being updated\n"; sub update_page { my ($id, $text, $summary, $minor, $admin, @rest) = @_; print '*'; my $pwd = $admin ? 'foo' : 'wrong'; $id = url_encode($id); $text = url_encode($text); $summary = url_encode($summary); $minor = $minor ? 'on' : 'off'; my $rest = join(' ', @rest); $redirect = `perl wiki.pl Save=1 title=$id summary=$summary recent_edit=$minor text=$text pwd=$pwd $rest`; $output = `perl wiki.pl action=browse id=$id`; return $output; } print "+ means that a page is being retrieved\n"; sub get_page { print '+'; open(F,"perl wiki.pl @_ |"); my $output = ; close F; return $output; } print ". means a test\n"; sub test_page { my $page = shift; my $printpage = 0; foreach my $str (@_) { print '.'; if ($page =~ /$str/) { $passed++; } else { $failed++; $printpage = 1; print "\nSimple Test: Did not find \"", $str, '"'; } } print "\n\nPage content:\n", $page, "\n" if $printpage; } sub test_page_negative { my $page = shift; my $printpage = 0; foreach my $str (@_) { print '.'; if ($page =~ /$str/) { $failed++; $printpage = 1; print "\nSimple negative Test: Found \"", $str, '"'; } else { $passed++; } } print "\n\nPage content:\n", $page, "\n" if $printpage; } sub run_tests { # translate embedded newlines (other backslashes remain untouched) my %New; foreach (keys %Test) { $Test{$_} =~ s/\\n/\n/g; my $new = $Test{$_}; s/\\n/\n/g; $New{$_} = $new; } # Note that the order of tests is not specified! my $output; foreach my $input (keys %New) { print '.'; { local *STDOUT; $output = ''; open(STDOUT, '>', \$output) or die "Can't open memory file: $!"; $FootnoteNumber = 0; ApplyRules($input, 1); } if ($output eq $New{$input}) { $passed++; } else { $failed++; print "\n\n---- input:\n", $input, "\n---- output:\n", $output, "\n---- instead of:\n", $New{$input}, "\n----\n"; } } } sub remove_rule { my $rule = shift; my @list = (); my $found = 0; foreach my $item (@MyRules) { if ($item ne $rule) { push @list, $item; } else { $found = 1; } } die "Rule not found" unless $found; @MyRules = @list; } sub add_module { my $mod = shift; mkdir $ModuleDir unless -d $ModuleDir; symlink("/mnt/src/oddmuse/modules/$mod", "$ModuleDir/$mod") or die "Cannot symlink $mod: $!" unless -l "$ModuleDir/$mod"; do "$ModuleDir/$mod"; @MyRules = sort {$RuleOrder{$a} <=> $RuleOrder{$b}} @MyRules; } sub remove_module { my $mod = shift; mkdir $ModuleDir unless -d $ModuleDir; unlink("$ModuleDir/$mod") or die "Cannot unlink: $!"; } sub clear_pages { system('/bin/rm -rf /tmp/oddmuse'); die "Cannot remove /tmp/oddmuse!\n" if -e '/tmp/oddmuse'; mkdir '/tmp/oddmuse'; open(F,'>/tmp/oddmuse/config'); print F "\$AdminPass = 'foo';\n"; print F "\$SurgeProtection = 0;\n"; close(F); $IndexInit = 0; %IndexHash = (); $InterSiteInit = 0; %InterSite = (); $NearSiteInit = 0; %NearSite = (); %NearSearch = (); } # Create temporary data directory as expected by the script my $str; use Getopt::Std; our($opt_m, $opt_x); getopts('mx'); goto markup if $opt_m; goto fixme if $opt_x; $ENV{'REMOTE_ADDR'} = 'test-markup'; # -------------------- print '[pagenames]'; clear_pages(); update_page('.dotfile', 'old content', 'older summary'); update_page('.dotfile', 'some content', 'some summary'); test_page(get_page('.dotfile'), 'some content'); test_page(get_page('action=browse id=.dotfile revision=1'), 'old content'); test_page(get_page('action=history id=.dotfile'), 'older summary', 'some summary'); # -------------------- print '[rollback]'; clear_pages(); # old revisions update_page('InnocentPage', 'Innocent.', 'good guy zero'); update_page('NicePage', 'Friendly content.', 'good guy one'); update_page('OtherPage', 'Other cute content 1.', 'another good guy'); update_page('OtherPage', 'Other cute content 2.', 'another good guy'); update_page('OtherPage', 'Other cute content 3.', 'another good guy'); update_page('OtherPage', 'Other cute content 4.', 'another good guy'); update_page('OtherPage', 'Other cute content 5.', 'another good guy'); update_page('OtherPage', 'Other cute content 6.', 'another good guy'); update_page('OtherPage', 'Other cute content 7.', 'another good guy'); update_page('OtherPage', 'Other cute content 8.', 'another good guy'); update_page('OtherPage', 'Other cute content 9.', 'another good guy'); update_page('OtherPage', 'Other cute content 10.', 'another good guy'); update_page('OtherPage', 'Other cute content 11.', 'another good guy'); # good revisions -- need a different timestamp than the old revisions! sleep(1); update_page('InnocentPage', 'Lamb.', 'good guy zero'); update_page('OtherPage', 'Other cute content 12.', 'another good guy'); update_page('MinorPage', 'Dumdidu', 'tester'); # last good revision -- needs a different timestamp than the good revisions! sleep(1); update_page('NicePage', 'Nice content.', 'good guy two'); # bad revisions -- need a different timestamp than the last good revision! sleep(1); update_page('NicePage', 'Evil content.', 'vandal one'); update_page('OtherPage', 'Other evil content.', 'another vandal'); update_page('NicePage', 'Bad content.', 'vandal two'); update_page('EvilPage', 'Spam!', 'vandal three'); update_page('AnotherEvilPage', 'More Spam!', 'vandal four'); update_page('AnotherEvilPage', 'Still More Spam!', 'vandal five'); update_page('MinorPage', 'Ramtatam', 'tester', 1); test_page(get_page('NicePage'), 'Bad content'); test_page(get_page('InnocentPage'), 'Lamb'); get_page('action=rc all=1 pwd=foo') =~ /.*action=rollback;to=([0-9]+).*?-- good guy two/; test_page(get_page("action=rollback to=$1"), 'restricted to administrators'); test_page(get_page("action=rollback to=$1 pwd=foo"), 'Rolling back changes', 'NicePage rolled back', 'OtherPage rolled back'); test_page(get_page('NicePage'), 'Nice content'); test_page(get_page('OtherPage'), 'Other cute content 12'); test_page(get_page('EvilPage'), 'DeletedPage'); test_page(get_page('AnotherEvilPage'), 'DeletedPage'); test_page(get_page('InnocentPage'), 'Lamb'); test_page(get_page('action=rc showedit=1'), 'MinorPage[ .]*test-markup *-- *Rollback to [^<>]* *\(minor\)', 'NicePage[ .]*test-markup *-- *Rollback to [^<>]* *'); # -------------------- print '[clusters]'; AppendStringToFile($ConfigFile, "\$PageCluster = 'Cluster';\n"); update_page('ClusterIdea', 'This is just a page.', 'one'); update_page('ClusterIdea', "This is just a page.\nBut somebody has to do it.", 'two'); update_page('ClusterIdea', "This is just a page.\nNobody wants it.", 'three', 1); update_page('ClusterIdea', "MainPage\nThis is just a page.\nBut somebody has to do it.", 'four'); @Test = split('\n',<<'EOT'); Cluster.*MainPage EOT test_page(get_page('action=rc'), @Test); @Test = split('\n',<<'EOT'); Cluster.*MainPage ClusterIdea.*two ClusterIdea.*one EOT test_page(get_page('action=rc all=1'), @Test); @Test = split('\n',<<'EOT'); Cluster.*MainPage ClusterIdea.*three ClusterIdea.*two ClusterIdea.*one EOT test_page(get_page('action=rc all=1 showedit=1'), @Test); @Test = split('\n',<<'EOT'); Finally the main page Updates in the last [0-9]+ days diff.*ClusterIdea.*history.*four for.*MainPage.*only 1 day action=browse;id=MainPage;rcclusteronly=MainPage;days=1;all=0;showedit=0 EOT update_page('MainPage', 'Finally the main page.'); test_page(get_page('action=browse id=MainPage rcclusteronly=MainPage'), @Test); @Test = split('\n',<<'EOT'); Finally the main page Updates in the last [0-9]+ days diff.*ClusterIdea.*four for.*MainPage.*only 1 day EOT test_page(get_page('action=browse id=MainPage rcclusteronly=MainPage showedit=1'), (@Test, 'action=browse;id=MainPage;rcclusteronly=MainPage;days=1;all=0;showedit=1')); test_page(get_page('action=browse id=MainPage rcclusteronly=MainPage all=1'), (@Test, 'action=browse;id=MainPage;rcclusteronly=MainPage;days=1;all=1;showedit=0')); @Test = split('\n',<<'EOT'); Finally the main page Updates in the last [0-9]+ days diff.*ClusterIdea.*five diff.*ClusterIdea.*four for.*MainPage.*only 1 day action=browse;id=MainPage;rcclusteronly=MainPage;days=1;all=1;showedit=1 EOT update_page('ClusterIdea', "MainPage\nSomebody has to do it.", 'five', 1); test_page(get_page('action=browse id=MainPage rcclusteronly=MainPage all=1 showedit=1'), @Test); # -------------------- print '[rss]'; # create simple config file use Cwd; $dir = cwd; $uri = "file://$dir"; # RSS 2.0 update_page('RSS', ""); test_page(get_page('RSS'), join('(.|\n)*', # verify the *order* of things. 'The Hydra', 'The War On Hydra', 'Nation Demolished', 'Drummers', 'Death', 'Audio Terrorists', 'Crowds', 'Assholes', 'iraq_saddam03', 'brudermann')); @Test = split('\n',<<'EOT'); Fania All Stars - Bamboleo http://www.audioscrobbler.com/music/Fania\+All\+Stars/_/Bamboleo EOT update_page('RSS', ""); test_page(get_page('RSS'), @Test); @Test = split('\n',<<'EOT'); PRNewswire: Texas Software Startup, Serenity Systems, Advises Business Users to Get Off Windows http://linuxtoday.com/story.php3\?sn=9443 LinuxPR: MyDesktop Launches Linux Software Section http://linuxtoday.com/story.php3\?sn=9442 LinuxPR: Franklin Institute Science Museum Chooses Linux http://linuxtoday.com/story.php3\?sn=9441 Yellow Dog Linux releases updated am-utils http://linuxtoday.com/story.php3\?sn=9440 LinuxPR: LinuxCare Adds Laser5 Linux To Roster of Supported Linux Distributions http://linuxtoday.com/story.php3\?sn=9439 EOT update_page('RSS', ""); test_page(get_page('RSS'), @Test); @Test = split('\n',<<'EOT'); Xskat 3.1 http://freshmeat.net/news/1999/09/01/936224942.html Java Test Driver 1.1 http://freshmeat.net/news/1999/09/01/936224907.html WaveLAN/IEEE driver 1.0.1 http://freshmeat.net/news/1999/09/01/936224545.html macfork 1.0 http://freshmeat.net/news/1999/09/01/936224336.html QScheme 0.2.2 http://freshmeat.net/news/1999/09/01/936223755.html CompuPic 4.6 build 1018 http://freshmeat.net/news/1999/09/01/936223729.html eXtace 1.1.16 http://freshmeat.net/news/1999/09/01/936223709.html GTC 0.3 http://freshmeat.net/news/1999/09/01/936223686.html RocketJSP 0.9c http://freshmeat.net/news/1999/09/01/936223646.html Majik 3D 0.0/M3 http://freshmeat.net/news/1999/09/01/936223622.html EOT update_page('RSS', ""); test_page(get_page('RSS'), @Test); @Test = split('\n',<<'EOT'); GTKeyboard 0.85 http://freshmeat.net/news/1999/06/21/930003829.html EOT update_page('RSS', ""); test_page(get_page('RSS'), @Test); @Test = split('\n',<<'EOT');
  • Berufsverbot für Mediendesigner\?
  • Experimentell bestätigt: http://www.heise.de/tp/deutsch/inhalt/lis/15882/1.html Clash im Internet? http://www.heise.de/tp/deutsch/special/med/15787/1.html Die Einheit der Umma gegen die jüdische Weltmacht http://www.heise.de/tp/deutsch/special/ost/15879/1.html Im Krieg mit dem Satan http://www.heise.de/tp/deutsch/inhalt/co/15880/1.html Der dritte Mann http://www.heise.de/tp/deutsch/inhalt/co/15876/1.html Leicht neben dem Ziel http://www.heise.de/tp/deutsch/inhalt/mein/15867/1.html Wale sollten Nordkorea meiden http://www.heise.de/tp/deutsch/inhalt/co/15878/1.html Afghanistan-Krieg und Irak-Besatzung haben al-Qaida gestärkt http://www.heise.de/tp/deutsch/inhalt/co/15874/1.html Der mit dem Dinosaurier tanzt http://www.heise.de/tp/deutsch/inhalt/lis/15863/1.html Terroranschlag überschattet das Genfer Abkommen http://www.heise.de/tp/deutsch/special/ost/15873/1.html "Barwatch" in Kanada http://www.heise.de/tp/deutsch/inhalt/te/15871/1.html Die Türken kommen! http://www.heise.de/tp/deutsch/special/irak/15870/1.html Neue Regelungen zur Telekommunikationsüberwachung http://www.heise.de/tp/deutsch/inhalt/te/15869/1.html Ein Lied vom Tod http://www.heise.de/tp/deutsch/inhalt/kino/15862/1.html EOT update_page('RSS', ""); test_page(get_page('RSS'), @Test); # Note, cannot identify BayleShanks as author in the mb.rdf @Test = split('\n',<<'EOT'); MeatBall:LionKimbro 2003-10-24T22:49:33\+06:00 CommunityWiki:RecentNearChanges http://www.usemod.com/cgi-bin/mb.pl\?LionKimbro 2003-10-24T21:02:53\+00:00 unified rc for here and meatball \. \. \. \. AlexSchroeder http://www.emacswiki.org/cgi-bin/community\?action=browse;id=RecentNearChanges;revision=1 EOT update_page('RSS', ""); test_page(get_page('RSS'), @Test); # -------------------- print '[redirection]'; update_page('Miles_Davis', 'Featuring [[John Coltrane]]'); # plain link update_page('John_Coltrane', '#REDIRECT Coltrane'); # no redirect update_page('Sonny_Stitt', '#REDIRECT [[Stitt]]'); # redirect update_page('Keith_Jarret', 'Plays with [[Gary Peacock]]'); # link to perm. anchor update_page('Jack_DeJohnette', 'A friend of [::Gary Peacock]'); # define perm. anchor test_page(get_page('Miles_Davis'), ('Featuring', 'John Coltrane')); test_page(get_page('John_Coltrane'), ('#REDIRECT Coltrane')); test_page(get_page('Sonny_Stitt'), ('Status: 302', 'Location: .*wiki.pl\?action=browse;oldid=Sonny_Stitt;id=Stitt')); test_page(get_page('Keith_Jarret'), ('Plays with', 'wiki.pl/Jack_DeJohnette#Gary_Peacock', 'Keith Jarret', 'Gary Peacock')); test_page(get_page('Gary_Peacock'), ('Status: 302', 'Location: .*wiki.pl/Jack_DeJohnette#Gary_Peacock')); test_page(get_page('Jack_DeJohnette'), ('A friend of', 'Gary Peacock', 'name="Gary_Peacock"', 'class="definition"', 'title="Click to search for references to this permanent anchor"')); # -------------------- print '[recent changes]'; $host1 = 'tisch'; $host2 = 'stuhl'; $ENV{'REMOTE_ADDR'} = $host1; update_page('Mendacibombus', 'This is the place.', 'samba', 0, 0, ('username=berta')); update_page('Bombia', 'This is the time.', 'tango', 0, 0, ('username=alex')); $ENV{'REMOTE_ADDR'} = $host2; update_page('Confusibombus', 'This is order.', 'ballet', 1, 0, ('username=berta')); update_page('Mucidobombus', 'This is chaos.', 'tarantella', 0, 0, ('username=alex')); @Positives = split('\n',<<'EOT'); for time or place only Mendacibombus.*samba Bombia.*tango EOT @Negatives = split('\n',<<'EOT'); Confusibombus ballet Mucidobombus tarantella EOT $page = get_page('action=rc rcfilteronly=time%20or%20place'); test_page($page, @Positives); test_page_negative($page, @Negatives); @Positives = split('\n',<<'EOT'); Mucidobombus.*tarantella EOT @Negatives = split('\n',<<'EOT'); Mendacibombus samba Bombia tango Confusibombus ballet EOT $page = get_page('action=rc rcfilteronly=order%20or%20chaos'); test_page($page, @Positives); test_page_negative($page, @Negatives); @Positives = split('\n',<<'EOT'); EOT @Negatives = split('\n',<<'EOT'); Mucidobombus tarantella Mendacibombus samba Bombia tango Confusibombus ballet EOT $page = get_page('action=rc rcfilteronly=order%20and%20chaos'); test_page($page, @Positives); test_page_negative($page, @Negatives); @Positives = split('\n',<<'EOT'); Mendacibombus.*samba Bombia.*tango EOT @Negatives = split('\n',<<'EOT'); Mucidobombus tarantella Confusibombus ballet EOT $page = get_page('action=rc rchostonly=tisch'); test_page($page, @Positives); test_page_negative($page, @Negatives); @Positives = split('\n',<<'EOT'); Mucidobombus.*tarantella EOT @Negatives = split('\n',<<'EOT'); Confusibombus ballet Bombia tango Mendacibombus samba EOT $page = get_page('action=rc rchostonly=stuhl'); # no minor edits! test_page($page, @Positives); test_page_negative($page, @Negatives); @Positives = split('\n',<<'EOT'); Mucidobombus.*tarantella Confusibombus.*ballet EOT @Negatives = split('\n',<<'EOT'); Mendacibombus samba Bombia tango EOT $page = get_page('action=rc rchostonly=stuhl showedit=1'); # with minor edits! test_page($page, @Positives); test_page_negative($page, @Negatives); @Positives = split('\n',<<'EOT'); Mendacibombus.*samba EOT @Negatives = split('\n',<<'EOT'); Mucidobombus tarantella Bombia tango Confusibombus ballet EOT $page = get_page('action=rc rcuseronly=berta'); test_page($page, @Positives); test_page_negative($page, @Negatives); @Positives = qw(Mucidobombus.*tarantella Bombia.*tango); @Negatives = qw(Confusibombus ballet Mendacibombus samba); $page = get_page('action=rc rcuseronly=alex'); test_page($page, @Positives); test_page_negative($page, @Negatives); @Positives = qw(Bombia.*tango); @Negatives = qw(Mucidobombus tarantella Confusibombus ballet Mendacibombus samba); $page = get_page('action=rc rcidonly=Bombia'); test_page($page, @Positives); test_page_negative($page, @Negatives); # -------------------- print '[conflicts]'; # Using the example files from the diff3 manual my $lao_file = q{The Way that can be told of is not the eternal Way; The name that can be named is not the eternal name. The Nameless is the origin of Heaven and Earth; The Named is the mother of all things. Therefore let there always be non-being, so we may see their subtlety, And let there always be being, so we may see their outcome. The two are the same, But after they are produced, they have different names. }; my $lao_file_1 = q{The Tao that can be told of is not the eternal Tao; The name that can be named is not the eternal name. The Nameless is the origin of Heaven and Earth; The Named is the mother of all things. Therefore let there always be non-being, so we may see their subtlety, And let there always be being, so we may see their outcome. The two are the same, But after they are produced, they have different names. }; my $lao_file_2 = q{The Way that can be told of is not the eternal Way; The name that can be named is not the eternal name. The Nameless is the origin of Heaven and Earth; The Named is the mother of all things. Therefore let there always be non-being, so we may see their simplicity, And let there always be being, so we may see the result. The two are the same, But after they are produced, they have different names. }; my $tzu_file = q{The Nameless is the origin of Heaven and Earth; The named is the mother of all things. Therefore let there always be non-being, so we may see their subtlety, And let there always be being, so we may see their outcome. The two are the same, But after they are produced, they have different names. They both may be called deep and profound. Deeper and more profound, The door of all subtleties! }; my $tao_file = q{The Way that can be told of is not the eternal Way; The name that can be named is not the eternal name. The Nameless is the origin of Heaven and Earth; The named is the mother of all things. Therefore let there always be non-being, so we may see their subtlety, And let there always be being, so we may see their result. The two are the same, But after they are produced, they have different names. -- The Way of Lao-Tzu, tr. Wing-tsit Chan }; clear_pages(); # simple edit $ENV{'REMOTE_ADDR'} = 'confusibombus'; test_page(update_page('ConflictTest', $lao_file), 'The Way that can be told of is not the eternal Way'); # edit from another address should result in conflict warning $ENV{'REMOTE_ADDR'} = 'megabombus'; test_page(update_page('ConflictTest', $tzu_file), 'The Nameless is the origin of Heaven and Earth'); # test cookie! test_page($redirect, map { UrlEncode($_); } ('This page was changed by somebody else', 'Please check whether you overwrote those changes')); # test normal merging -- first get oldtime, then do two conflicting edits # we need to wait at least a second after the last test in order to not # confuse oddmuse. sleep(2); update_page('ConflictTest', $lao_file); $_ = `perl wiki.pl action=edit id=ConflictTest`; /name="oldtime" value="([0-9]+)"/; my $oldtime = $1; sleep(2); $ENV{'REMOTE_ADDR'} = 'confusibombus'; update_page('ConflictTest', $lao_file_1); sleep(2); # merge success has lines from both lao_file_1 and lao_file_2 $ENV{'REMOTE_ADDR'} = 'megabombus'; test_page(update_page('ConflictTest', $lao_file_2, '', '', '', "oldtime=$oldtime"), 'The Tao that can be told of', # file 1 'The name that can be named', # both 'so we may see their simplicity'); # file 2 # test conflict during merging -- first get oldtime, then do two conflicting edits sleep(2); update_page('ConflictTest', $tzu_file); $_ = `perl wiki.pl action=edit id=ConflictTest`; /name="oldtime" value="([0-9]+)"/; $oldtime = $1; sleep(2); $ENV{'REMOTE_ADDR'} = 'confusibombus'; update_page('ConflictTest', $tao_file); sleep(2); $ENV{'REMOTE_ADDR'} = 'megabombus'; test_page(update_page('ConflictTest', $lao_file, '', '', '', "oldtime=$oldtime"), q{
    <<<<<<< ancestor
    =======
    The Way that can be told of is not the eternal Way;
    The name that can be named is not the eternal name.
    >>>>>>> other
    
    }, q{
    <<<<<<< you
    ||||||| ancestor
    They both may be called deep and profound.
    Deeper and more profound,
    The door of all subtleties!
    =======
    
      -- The Way of Lao-Tzu, tr. Wing-tsit Chan
    >>>>>>> other
    
    }); @Test = split('\n',<<'EOT'); This page was changed by somebody else The changes conflict EOT test_page($redirect, map { UrlEncode($_); } @Test); # test cookie! # test conflict during merging without merge! -- first get oldtime, then do two conflicting edits AppendStringToFile($ConfigFile, "\$ENV{'PATH'} = '';\n"); sleep(2); update_page('ConflictTest', $lao_file); $_ = `perl wiki.pl action=edit id=ConflictTest`; /name="oldtime" value="([0-9]+)"/; $oldtime = $1; sleep(2); $ENV{'REMOTE_ADDR'} = 'confusibombus'; update_page('ConflictTest', $lao_file_1); sleep(2); # merge not available -- must look for message $ENV{'REMOTE_ADDR'} = 'megabombus'; test_page(update_page('ConflictTest', $lao_file_2, '', '', '', "oldtime=$oldtime"), 'The Way that can be told of is not the eternal Way', # file 2 'so we may see their simplicity', # file 2 'so we may see the result'); # file 2 test_page($redirect, map { UrlEncode($_) } ('This page was changed by somebody else', 'Please check whether you overwrote those changes')); # test cookie! # -------------------- print '[html cache]'; AppendStringToFile($ConfigFile, "\$WikiLinks = 0;\n"); ### Maintenance with cache resetting @Test = split('\n',<<'EOT'); This is a WikiLink. EOT test_page(update_page('CacheTest', 'This is a WikiLink.', '', 1), @Test); AppendStringToFile($ConfigFile, "\$WikiLinks = 1;\n"); # without new edit, the cached version persists test_page(get_page('CacheTest'), @Test); # refresh the cache using the all action @Test = split('\n',<<'EOT'); This is a WikiLink\?. EOT get_page('action=all cache=0'); test_page(get_page('CacheTest'), @Test); # -------------------- print '[search and replace]'; # Test search @Test = split('\n',<<'EOT');

    Search for: fooz

    1 pages found.

    SearchAndReplace This is fooz and this is barz. EOT update_page('SearchAndReplace', 'This is fooz and this is barz.', '', 1); test_page(get_page('search=fooz'), @Test); # Make sure only admins can replace @Test = split('\n',<<'EOT'); This operation is restricted to administrators only... EOT test_page(get_page('search=foo replace=bar'), @Test); # Simple replace @Test = split('\n',<<'EOT');

    Replaced: fooz -> fuuz

    1 pages found.

    This is fuuz and this is barz. EOT test_page(get_page('search=fooz replace=fuuz pwd=foo'), @Test); # Replace with backreferences @Test = split('\n',<<'EOT'); This is xfuu and this is xbar. EOT get_page('search=([a-z]%2b)z replace=x%241 pwd=foo'); test_page(get_page('SearchAndReplace'), @Test); ## Check headers especially the quoting of non-ASCII characters. @Test = split('\n',<<'EOT');

    Alexander Schröder

    Edit Alexander Schröder! EOT test_page(update_page("Alexander_Schröder", "Edit [[Alexander Schröder]]!"), @Test); # -------------------- print '[banning]'; ## Edit banned hosts as a normal user should fail $localhost = 'confusibombus'; $ENV{'REMOTE_ADDR'} = $localhost; @Test = split('\n',<<'EOT'); Describe the new page here EOT test_page(update_page('BannedHosts', "Foo\nBar\n $localhost\n", 'banning me'), @Test); ## Edit banned hosts as admin should succeed @Test = split('\n',<<"EOT"); Foo $localhost EOT test_page(update_page('BannedHosts', "Foo\nBar\n $localhost\n", 'banning me', 0, 1), @Test); ## Edit banned hosts as a normal user should fail @Test = split('\n',<<"EOT"); Foo $localhost EOT test_page(update_page('BannedHosts', "Something else.", 'banning me'), @Test); ## Try to edit another page as a banned user @Test = split('\n',<<'EOT'); Describe the new page here EOT test_page(update_page('BannedUser', 'This is a test which should fail.', 'banning test'), @Test); ## Try to edit the same page as a banned user with admin password @Test = split('\n',<<'EOT'); This is a test EOT test_page(update_page('BannedUser', 'This is a test.', 'banning test', 0, 1), @Test); ## Unbann myself again, testing the regexp @Test = split('\n',<<'EOT'); Foo Bar EOT test_page(update_page('BannedHosts', "Foo\nBar\n", 'banning me', 0, 1), @Test); ## Banning content @Test = split('\n',<<'EOT'); banned text wiki administrator matched See .*BannedContent.* for more information EOT update_page('BannedContent', "cosa\n mafia\nnostra\n", 'one banned word', 0, 1); test_page(update_page('CriminalPage', 'This is about the mafia'), 'Describe the new page here'); test_page($redirect, @Test); test_page(update_page('CriminalPage', 'This is about the cosa nostra'), 'cosa nostra'); # -------------------- print '[journal]'; ## Create diary pages update_page('2003-06-13', "Freitag"); update_page('2003-06-14', "Samstag"); update_page('2003-06-15', "Sonntag"); @Test = split('\n',<<'EOT'); This is my journal 2003-06-15 Sonntag 2003-06-14 Samstag EOT test_page(update_page('Summary', "This is my journal:\n\n"), @Test); test_page(update_page('2003-01-01', "This is my journal -- recursive:\n\n"), @Test); push @Test, 'journal'; test_page(update_page('2003-01-01', "This is my journal -- truly recursive:\n\n"), @Test); @Test = split('\n',<<'EOT'); 2003-06-15(.|\n)*2003-06-14 EOT test_page(update_page('Summary', "Counting down:\n\n"), @Test); @Test = split('\n',<<'EOT'); 2003-01-01(.|\n)*2003-06-13(.|\n)*2003-06-14 EOT test_page(update_page('Summary', "Counting up:\n\n"), @Test); # -------------------- print '[revisions]'; clear_pages(); ## Test revision and diff stuff update_page('KeptRevisions', 'first'); update_page('KeptRevisions', 'second'); update_page('KeptRevisions', 'third'); update_page('KeptRevisions', 'fourth', '', 1); update_page('KeptRevisions', 'fifth', '', 1); # Show the current revision @Test = split('\n',<<'EOT'); KeptRevisions fifth EOT test_page(get_page(KeptRevisions), @Test); # Show the other revision @Test = split('\n',<<'EOT'); Showing revision 2 second EOT test_page(get_page('action=browse revision=2 id=KeptRevisions'), @Test); @Test = split('\n',<<'EOT'); Showing revision 1 first EOT test_page(get_page('action=browse revision=1 id=KeptRevisions'), @Test); # Show the current revision if an inexisting revision is asked for @Test = split('\n',<<'EOT'); Revision 9 not available \(showing current revision instead\) fifth EOT test_page(get_page('action=browse revision=9 id=KeptRevisions'), @Test); # Show a major diff @Test = split('\n',<<'EOT'); Difference \(from prior major revision\) third fifth EOT test_page(get_page('action=browse diff=1 id=KeptRevisions'), @Test); # Show a minor diff @Test = split('\n',<<'EOT'); Difference \(from prior minor revision\) fourth fifth EOT test_page(get_page('action=browse diff=2 id=KeptRevisions'), @Test); # Show a diff from the history page comparing two specific revisions @Test = split('\n',<<'EOT'); Difference \(from revision 2 to revision 4\) second fourth EOT test_page(get_page('action=browse diff=1 revision=4 diffrevision=2 id=KeptRevisions'), @Test); # -------------------- print '[lock on creation]'; ## Create a sample page, and test for regular expressions in the output @Test = split('\n',<<'EOT'); SandBox This is a test.

    SandBox

    EOT test_page(update_page('SandBox', 'This is a test.', 'first test'), @Test); ## Test RecentChanges @Test = split('\n',<<'EOT'); RecentChanges first test EOT test_page(get_page('action=rc'), @Test); ## Updated the page @Test = split('\n',<<'EOT'); RecentChanges This is another test. EOT test_page(update_page('SandBox', 'This is another test.', 'second test'), @Test); ## Test RecentChanges @Test = split('\n',<<'EOT'); RecentChanges second test EOT test_page(get_page('action=rc'), @Test); ## Attempt to create InterMap page as normal user @Test = split('\n',<<'EOT'); Describe the new page here EOT test_page(update_page('InterMap', " OddMuse http://www.emacswiki.org/cgi-bin/oddmuse.pl?\n", 'required'), @Test); ## Create InterMap page as admin ## The OddMuse intermap entry is required for later tests. @Test = split('\n',<<'EOT'); OddMuse http://www\.emacswiki\.org/cgi-bin/oddmuse\.pl PlanetMath http://planetmath\.org/encyclopedia/\%s\.html EOT test_page(update_page('InterMap', " OddMuse http://www.emacswiki.org/cgi-bin/oddmuse.pl?\n PlanetMath http://planetmath.org/encyclopedia/%s.html", 'required', 0, 1), @Test); ## Verify the InterMap stayed locked @Test = split('\n',<<'EOT'); OddMuse EOT test_page(update_page('InterMap', "All your edits are blong to us!\n", 'required'), @Test); # -------------------- print '[despam module]'; # create simple config file add_module('despam.pl'); update_page('HilariousPage', "Ordinary text."); update_page('HilariousPage', "Hilarious text."); update_page('HilariousPage', "Spam from example.com."); update_page('NoPage', "Spam from example.com."); update_page('OrdinaryPage', "Spam from example.com."); update_page('OrdinaryPage', "Ordinary text."); update_page('ExpiredPage', "Spam from example.com."); update_page('ExpiredPage', "More spam from example.com."); update_page('ExpiredPage', "Still more spam from example.com."); update_page('BannedContent', " example\\.com\n", 'required', 0, 1); unlink('/tmp/oddmuse/keep/E/ExpiredPage/1.kp') or die "Cannot delete kept revision: $!"; @Test = split('\n',<<'EOT'); HilariousPage.*Revert to revision 2 NoPage.*Marked as DeletedPage OrdinaryPage ExpiredPage.*Cannot find unspammed revision EOT test_page(get_page('action=despam'), @Test); test_page(get_page('ExpiredPage'), 'Still more spam'); test_page(get_page('OrdinaryPage'), 'Ordinary text'); test_page(get_page('NoPage'), 'DeletedPage'); test_page(get_page('HilariousPage'), 'Hilarious text'); test_page(get_page('BannedContent'), 'example\\\.com'); # -------------------- print '[near]'; clear_pages(); CreateDir($NearDir); WriteStringToFile("$NearDir/EmacsWiki", "AlexSchroeder\nFooBar\n"); update_page('InterMap', " EmacsWiki http://www.emacswiki.org/cgi-bin/wiki/%s\n", 'required', 0, 1); update_page('NearMap', " EmacsWiki" . " http://www.emacswiki.org/cgi-bin/emacs?action=index;raw=1" . " http://www.emacswiki.org/cgi-bin/emacs?search=%s;raw=1;near=0\n", 'required', 0, 1); test_page(update_page('FooBaz', "Try FooBar instead!\n"), map { quotemeta } ( 'FooBar', '')); test_page(update_page('FooBar', "Test by AlexSchroeder!\n"), map { quotemeta } ( '

    The same page on other sites:
    ' . '' . 'EmacsWiki:FooBar')); test_page(get_page('search=alexschroeder'), map { quotemeta } ( '

    Near pages:

    ', 'AlexSchroeder
    ')); # -------------------- print '[links]'; clear_pages(); add_module('links.pl'); update_page('InterMap', " Oddmuse http://www.emacswiki.org/cgi-bin/oddmuse.pl?\n", 'required', 0, 1); update_page('a', 'Oddmuse:foo(no) [Oddmuse:bar] [Oddmuse:baz text] ' . '[Oddmuse:bar(no)] [Oddmuse:baz(no) text] ' . '[[Oddmuse:foo_(bar)]] [[[Oddmuse:foo (baz)]]] [[Oddmuse:foo (quux)|text]]'); @Test = map { quotemeta } split('\n',<<'EOT'); "a" -> "Oddmuse:foo" "a" -> "Oddmuse:bar" "a" -> "Oddmuse:baz" "a" -> "Oddmuse:foo_(bar)" "a" -> "Oddmuse:foo (baz)" "a" -> "Oddmuse:foo (quux)" EOT test_page_negative(get_page('action=links raw=1'), @Test); test_page(get_page('action=links raw=1 inter=1'), @Test); @Test = map { quotemeta } split('\n',<<'EOT'); a: Oddmuse:foo Oddmuse:bar Oddmuse:baz Oddmuse:foo_(bar) EOT test_page_negative(get_page('action=links'), @Test); test_page(get_page('action=links inter=1'), @Test); AppendStringToFile($ConfigFile, "\$BracketWiki = 0;\n"); update_page('a', '[[b]] [[[c]]] [[d|e]] FooBar [FooBaz] [FooQuux fnord] '); @Test1 = split('\n',<<'EOT'); "a" -> "b" "a" -> "c" "a" -> "FooBar" "a" -> "FooBaz" "a" -> "FooQuux" EOT @Test2 = split('\n',<<'EOT'); "a" -> "d" EOT $page = get_page('action=links raw=1'); test_page($page, @Test1); test_page_negative($page, @Test2); AppendStringToFile($ConfigFile, "\$BracketWiki = 1;\n"); update_page('a', '[[b]] [[[c]]] [[d|e]] FooBar [FooBaz] [FooQuux fnord] ' . 'http://www.oddmuse.org/ [http://www.emacswiki.org/] ' . '[http://www.communitywiki.org/ cw]'); @Test1 = split('\n',<<'EOT'); "a" -> "b" "a" -> "c" "a" -> "d" "a" -> "FooBar" "a" -> "FooBaz" "a" -> "FooQuux" EOT @Test2 = split('\n',<<'EOT'); "a" -> "http://www.oddmuse.org/" "a" -> "http://www.emacswiki.org/" "a" -> "http://www.communitywiki.org/" EOT $page = get_page('action=links raw=1'); test_page($page, @Test1); test_page_negative($page, @Test2); $page = get_page('action=links raw=1 url=1'); test_page($page, @Test1, @Test2); $page = get_page('action=links raw=1 links=0 url=1'); test_page_negative($page, @Test1); test_page($page, @Test2); # -------------------- print '[link pattern]'; clear_pages(); $AllNetworkFiles = 1; update_page('HomePage', "This page exists."); update_page('InterMap', " Oddmuse http://www.emacswiki.org/cgi-bin/oddmuse.pl?\n PlanetMath http://planetmath.org/encyclopedia/%s.html", 'required', 0, 1); %Test = split('\n',<<'EOT'); file://home/foo/tutorial.pdf file://home/foo/tutorial.pdf file:///home/foo/tutorial.pdf file:///home/foo/tutorial.pdf image inline: [[image:HomePage]], [[image:OtherPage]] image inline: HomePage, [image:OtherPage]? traditional local link: HomePage, OtherPage traditional local link: HomePage, OtherPage? traditional local link with extra brackets: [HomePage], [OtherPage] traditional local link with extra brackets: [1], [OtherPage?] traditional local link with other text: [HomePage homepage], [OtherPage other page] traditional local link with other text: [HomePage homepage], [OtherPage? other page] free link: [[home page]], [[other page]] free link: [home page]?, [other page]? free link with extra brackets: [[[home page]]], [[[other page]]] free link with extra brackets: [home_page?], [other_page?] free link with other text: [[home page|da homepage]], [[other page|da other homepage]] free link with other text: [[home page|da homepage]], [[other page|da other homepage]] URL: http://www.oddmuse.org/ URL: http://www.oddmuse.org/ URL in text http://www.oddmuse.org/ like this URL in text http://www.oddmuse.org/ like this URL in brackets: [http://www.oddmuse.org/] URL in brackets: [1] URL in brackets with other text: [http://www.oddmuse.org/ oddmuse] URL in brackets with other text: oddmuse URL abbreviation: Oddmuse:Link_Pattern URL abbreviation: Oddmuse:Link_Pattern URL abbreviation with extra brackets: [Oddmuse:Link_Pattern] URL abbreviation with extra brackets: [1] URL abbreviation with other text: [Oddmuse:Link_Pattern link patterns] URL abbreviation with other text: link patterns URL abbreviation with meta characters: Oddmuse:Link+Pattern URL abbreviation with meta characters: Oddmuse:Link+Pattern URL abbreviation with meta characters and extra brackets: [Oddmuse:Link+Pattern] URL abbreviation with meta characters and extra brackets: [1] URL abbreviation with meta characters and other text: [Oddmuse:Link+Pattern link patterns] URL abbreviation with meta characters and other text: link patterns free URL abbreviation: [[Oddmuse:Link Pattern]] free URL abbreviation: Oddmuse:Link Pattern free URL abbreviation with extra brackets: [[[Oddmuse:Link Pattern]]] free URL abbreviation with extra brackets: [1] free URL abbreviation with other text: [[Oddmuse:Link Pattern|link patterns]] free URL abbreviation with other text: link patterns free URL abbreviation with meta characters: [[Oddmuse:Link+Pattern]] free URL abbreviation with meta characters: Oddmuse:Link+Pattern free URL abbreviation with meta characters and extra brackets: [[[Oddmuse:Link+Pattern]]] free URL abbreviation with meta characters and extra brackets: [1] free URL abbreviation with meta characters and other text: [[Oddmuse:Link+Pattern|link patterns]] free URL abbreviation with meta characters and other text: link patterns EOT run_tests(); $AllNetworkFiles = 0; $BracketWiki = 1; %Test = split('\n',<<'EOT'); traditional local link: HomePage, OtherPage traditional local link: HomePage, OtherPage? traditional local link with extra brackets: [HomePage], [OtherPage] traditional local link with extra brackets: [1], [OtherPage?] traditional local link with other text: [HomePage homepage], [OtherPage other page] traditional local link with other text: homepage, [OtherPage? other page] free link: [[home page]], [[other page]] free link: [home page]?, [other page]? free link with extra brackets: [[[home page]]], [[[other page]]] free link with extra brackets: [home_page?], [other_page?] free link with other text: [[home page|da homepage]], [[other page|da other homepage]] free link with other text: [home page? da homepage], [other page? da other homepage] URL: http://www.oddmuse.org/ URL: http://www.oddmuse.org/ URL in brackets: [http://www.oddmuse.org/] URL in brackets: [1] URL in brackets with other text: [http://www.oddmuse.org/ oddmuse] URL in brackets with other text: oddmuse URL abbreviation: Oddmuse:Link_Pattern URL abbreviation: Oddmuse:Link_Pattern URL abbreviation with extra brackets: [Oddmuse:Link_Pattern] URL abbreviation with extra brackets: [1] URL abbreviation with other text: [Oddmuse:Link_Pattern link patterns] URL abbreviation with other text: link patterns free URL abbreviation: [[Oddmuse:Link Pattern]] free URL abbreviation: Oddmuse:Link Pattern free URL abbreviation with extra brackets: [[[Oddmuse:Link Pattern]]] free URL abbreviation with extra brackets: [1] free URL abbreviation with other text: [[Oddmuse:Link Pattern|link pattern]] free URL abbreviation with other text: link pattern EOT run_tests(); $BracketWiki = 0; # -------------------- markup: print '[markup]'; clear_pages(); update_page('InterMap', " OddMuse http://www.emacswiki.org/cgi-bin/oddmuse.pl?\n PlanetMath http://planetmath.org/encyclopedia/%s.html", 'required', 0, 1); $NetworkFile = 1; %Smilies = ('HAHA!' => '/pics/haha.png'); %Test = split('\n',<<'EOT'); HAHA! HAHA! do not eat 0 from text do not eat 0 from text ordinary text ordinary text paragraph\n\nparagraph paragraph

    paragraph

    * one\n*two
    • one *two
    * one\n\n*two
    • one

    *two

    * one\n** two
    • one
      • two
    * one\n** two\n*** three\n* four
    • one
      • two
        • three
    • four
    * one\n** two\n*** three\n* four\n** five\n* six
    • one
      • two
        • three
    • four
      • five
    • six
    * one\n* two\n** one and two\n** two and three\n* three
    • one
    • two
      • one and two
      • two and three
    • three
    * one and *\n* two and * more
    • one and *
    • two and * more
    WikiWord WikiWord? WikiWord: WikiWord?: OddMuse OddMuse? OddMuse: OddMuse?: OddMuse:test OddMuse:test OddMuse:test: or not OddMuse:test: or not OddMuse:test, and foo OddMuse:test, and foo PlanetMath:ZipfsLaw, and foo PlanetMath:ZipfsLaw, and foo [OddMuse:test] [1] Foo::Bar Foo::Bar !WikiLink WikiLink !foo !foo ![[Free Link]] ![Free Link]? http://www.emacswiki.org http://www.emacswiki.org <http://www.emacswiki.org> http://www.emacswiki.org/ http://www.emacswiki.org/ http://www.emacswiki.org. http://www.emacswiki.org. http://www.emacswiki.org, http://www.emacswiki.org, http://www.emacswiki.org; http://www.emacswiki.org; http://www.emacswiki.org: http://www.emacswiki.org: http://www.emacswiki.org? http://www.emacswiki.org? http://www.emacswiki.org/? http://www.emacswiki.org/? http://www.emacswiki.org! http://www.emacswiki.org! http://www.emacswiki.org' http://www.emacswiki.org' http://www.emacswiki.org" http://www.emacswiki.org" http://www.emacswiki.org! http://www.emacswiki.org! http://www.emacswiki.org( http://www.emacswiki.org( http://www.emacswiki.org) http://www.emacswiki.org) http://www.emacswiki.org& http://www.emacswiki.org& http://www.emacswiki.org# http://www.emacswiki.org# http://www.emacswiki.org% http://www.emacswiki.org% [http://www.emacswiki.org] [1] [http://www.emacswiki.org] and [http://www.emacswiki.org] [1] and [2] [http://www.emacswiki.org], [1], [http://www.emacswiki.org and a label] and a label [file://home/foo/tutorial.pdf local link] local link file://home/foo/tutorial.pdf file://home/foo/tutorial.pdf file:///home/foo/tutorial.pdf file:///home/foo/tutorial.pdf mailto:alex@emacswiki.org mailto:alex@emacswiki.org EOT run_tests(); $NetworkFile = 0; # -------------------- print '[usemod module]'; do 'modules/usemod.pl'; InitVariables(); %Test = split('\n',<<'EOT'); * ''one\n** two
    • one
      • two
    # one\n# two
    1. one
    2. two
    * one\n# two
    • one
    1. two
    # one\n\n#two
    1. one

    #two

    # one\n# two\n## one and two\n## two and three\n# three
    1. one
    2. two
      1. one and two
      2. two and three
    3. three
    # one and #\n# two and # more
    1. one and #
    2. two and # more
    : one\n: two\n:: one and two\n:: two and three\n: three
    one
    two
    one and two
    two and three
    three
    : one and :)\n: two and :) more
    one and :)
    two and :) more
    : one\n\n:two
    one

    :two

    ; one:eins\n;two:zwei
    one
    eins ;two:zwei
    ; one:eins\n\n; two:zwei
    one
    eins
    two
    zwei
    ; a: b: c\n;; x: y: z
    a
    b: c
    x
    y: z
    * foo <b>bold\n* bar </b>
    • foo bold
    • bar </b>
    This is ''emphasized''. This is emphasized. This is '''strong'''. This is strong. This is ''longer emphasized'' text. This is longer emphasized text. This is '''longer strong''' text. This is longer strong text. This is '''''emphasized and bold''''' text. This is emphasized and bold text. This is ''emphasized '''and bold''''' text. This is emphasized and bold text. This is '''bold ''and emphasized''''' text. This is bold and emphasized text. This is ''emphasized text containing '''longer strong''' text''. This is emphasized text containing longer strong text. This is '''strong text containing ''emph'' text'''. This is strong text containing emph text. ||one||
    one
    || one ''two'' ||
    one two
    || one two ||
    one two
    introduction\n\n||one||two||three||\n||||one two||three|| introduction
    onetwothree
    one twothree
    ||one||two||three||\n||||one two||three||\n\nfooter
    onetwothree
    one twothree

    footer

    ||one||two||three||\n||||one two||three||\n\nfooter
    onetwothree
    one twothree

    footer

    || one|| two|| three||\n|||| one two|| three||\n\nfooter
    onetwothree
    one twothree

    footer

    ||one ||two ||three ||\n||||one two ||three ||\n\nfooter
    one two three
    one two three

    footer

    || one || two || three ||\n|||| one two || three ||\n\nfooter
    one two three
    one two three

    footer

    introduction\n\n||one||two||three||\n||||one two||three||\n\nfooter introduction
    onetwothree
    one twothree

    footer

    source
     source
    source\n etc\n
     source\n etc
    source\n \n etc\n
     source\n \n etc
    source\n \n etc\n\nother
     source\n \n etc

    other

    = title =

    title

    ==title=

    title

    ========fnord=
    fnord
    == nada\nnada == == nada nada == == nada ==
     == nada ==
    ==[[Free Link]]==

    [[Free Link]]

    EOT run_tests(); remove_rule(\&UsemodRule); # -------------------- print '[usemod options]'; # some patterns use options in regular expressions with /o and need to be recompiled do 'modules/usemod.pl'; $UseModSpaceRequired = 0; $UseModMarkupInTitles = 1; InitVariables(); %Test = split('\n',<<'EOT'); *one\n**two
    • one
      • two
    #one\n##two
    1. one
      1. two
    :one\n:two\n::one and two\n::two and three\n:three
    one
    two
    one and two
    two and three
    three
    ;one:eins\n;two:zwei
    one
    eins
    two
    zwei
    =='''title'''==

    title

    ==[[Free Link]]==

    [Free Link]?

    EOT run_tests(); $UseModSpaceRequired = 1; $UseModMarkupInTitles = 0; remove_rule(\&UsemodRule); # -------------------- print '[markup module]'; do 'modules/usemod.pl'; do 'modules/markup.pl'; InitVariables(); %Test = split('\n',<<'EOT'); foo foo /foo/ foo 5km/h or 6km/h 5km/h or 6km/h /foo/ bar foo bar /foo bar 5/ foo bar 5 6/22/2004 6/22/2004 #!/bin/sh #!/bin/sh put it in ~/elisp/ put it in ~/elisp/ see /usr/bin/ see /usr/bin/ to /usr/local/share/perl/! to /usr/local/share/perl/! we shall laugh/cry/run around naked we shall laugh/cry/run around naked da *foo* da foo da *foo bar 6* da foo bar 6 _foo_ foo foo_bar_baz foo_bar_baz _foo bar 4_ foo bar 4 this -> that this → that and this... and this… foo---bar foo—bar foo -- bar foo – bar foo\n----\nbar foo

    bar

    EOT run_tests(); remove_rule(\&UsemodRule); remove_rule(\&MarkupRule); # -------------------- print '[setext module]'; do 'modules/setext.pl'; do 'modules/link-all.pl'; %Test = split('\n',<<'EOT'); foo foo ~foo~ foo da *foo* da *foo* da **foo** bar da foo bar da `_**foo**_` bar da **foo** bar _foo_ foo foo_bar_baz foo_bar_baz _foo_bar_ baz foo bar baz and\nfoo\n===\n\nmore\n and

    foo

    more

    and\n\nfoo\n===\n\nmore\n and

    foo

    more

    and\nfoo \n--- \n\nmore\n and

    foo

    more

    and\nfoo\n---\n\nmore\n and

    foo

    more

    EOT run_tests(); *GetGotoBar = *OldLinkAllGetGotoBar; remove_rule(\&SeTextRule); remove_rule(\&LinkAllRule); # -------------------- print '[anchors module]'; do 'modules/anchors.pl'; do 'modules/link-all.pl'; # check compatibility %Test = split('\n',<<'EOT'); This is a [:day for fun and laughter]. This is a . [[#day for fun and laughter]]. day for fun and laughter. [[2004-08-17#day for fun and laughter]]. 2004-08-17#day for fun and laughter. [[[#day for fun and laughter]]]. [day for fun and laughter]. [[[2004-08-17#day for fun and laughter]]]. [1]. [[#day for fun and laughter|boo]]. [[#day for fun and laughter|boo]]. [[2004-08-17#day for fun and laughter|boo]]. [[2004-08-17#day for fun and laughter|boo]]. EOT run_tests(); $BracketWiki = 1; %Test = split('\n',<<'EOT'); [[2004-08-17#day for fun and laughter|boo]]. boo. EOT run_tests(); $BracketWiki = 0; remove_rule(\&AnchorsRule); remove_rule(\&LinkAllRule); # -------------------- print '[link-all module]'; clear_pages(); add_module('link-all.pl'); update_page('foo', 'link-all for bar'); test_page(get_page('action=browse define=1 id=foo'), quotemeta('bar')); %Test = split('\n',<<'EOT'); testing foo. testing foo. EOT run_tests(); *GetGotoBar = *OldLinkAllGetGotoBar; remove_rule(\&LinkAllRule); remove_module('link-all.pl'); # -------------------- print '[image module]'; do "modules/image.pl"; clear_pages(); update_page('bar', 'foo'); %Test = split('\n',<<'EOT'); [[image:foo]] [image:foo]? [[image:bar]] bar [[image:bar|alternative text]] alternative text [[image/left:bar|alternative text]] alternative text [[image:bar|alternative text|foo]] alternative text [[image/left:bar|alternative text|foo]] alternative text [[image/left:bar|alternative text|http://www.foo.com/]] alternative text EOT run_tests(); remove_rule(\&ImageSupportRule); # -------------------- print '[subscriberc module]'; # test together with link-all module add_module('subscriberc.pl'); %Test = split('\n',<<'EOT'); My subscribed pages: AlexSchroeder. My subscribed pages: AlexSchroeder. My subscribed pages: AlexSchroeder, [[LionKimbro]], [[Foo bar]]. My subscribed pages: AlexSchroeder, LionKimbro, Foo bar. My subscribed categories: CategoryDecisionMaking, CategoryBar. My subscribed categories: CategoryDecisionMaking, CategoryBar. My subscribed pages: AlexSchroeder, [[LionKimbro]], [[Foo bar]], categories: CategoryDecisionMaking. My subscribed pages: AlexSchroeder, LionKimbro, Foo bar, categories: CategoryDecisionMaking. EOT run_tests(); remove_rule(\&SubscribedRecentChangesRule); # -------------------- print '[toc module]'; add_module('toc.pl'); add_module('usemod.pl'); InitVariables(); %Test = split('\n',<<'EOT'); == make honey ==\n\nMoo.\n

    make honey

    Moo.

    EOT run_tests(); update_page('toc_test', "bla\n" . "=one=\n" . "bla\n" . "==two==\n" . "bla\n" . "==two==\n"); test_page(get_page('toc_test'), quotemeta('
    1. one
      1. two
      2. two
    '), quotemeta('

    one

    '), quotemeta('

    two

    ')); update_page('toc_test', "bla\n" . "==two=\n" . "bla\n" . "===three==\n" . "bla\n" . "==two==\n"); test_page(get_page('toc_test'), quotemeta('
    1. two
      1. three
    2. two
    '), quotemeta('

    two

    '), quotemeta('

    three

    ')); update_page('toc_test', "bla\n" . "==two=\n" . "bla\n" . "===three==\n" . "bla\n" . "=one=\n"); test_page(get_page('toc_test'), quotemeta('
    1. two
      1. three
    2. one
    '), quotemeta('

    two

    '), quotemeta('

    one

    ')); remove_rule(\&UsemodRule); remove_rule(\&TocRule); *GetHeader = *OldTocGetHeader; # -------------------- print '[comments]'; clear_pages(); AppendStringToFile($ConfigFile, "\$CommentsPrefix = 'Comments on ';\n"); get_page('title=Yadda', 'aftertext=This%20is%20my%20comment.', 'username=Alex'); test_page(get_page('Yadda'), 'Describe the new page'); get_page('title=Comments_on_Yadda', 'aftertext=This%20is%20my%20comment.', 'username=Alex'); test_page(get_page('Comments_on_Yadda'), 'This is my comment\.', '-- Alex'); get_page('title=Comments_on_Yadda', 'aftertext=This%20is%20another%20comment.', 'username=Alex', 'homepage=http%3a%2f%2fwww%2eoddmuse%2eorg%2f'); test_page(get_page('Comments_on_Yadda'), 'This is my comment\.', '-- Alex'); # -------------------- print '[headers in various modules]'; clear_pages(); # without portrait-support # nothing update_page('headers', "== no header ==\n\ntext\n"); test_page(get_page('headers'), '== no header =='); # usemod only add_module('usemod.pl'); update_page('headers', "== is header ==\n\ntext\n"); test_page(get_page('headers'), '

    is header

    '); remove_rule(\&UsemodRule); # toc only add_module('toc.pl'); update_page('headers', "== one ==\ntext\n== two ==\ntext\n== three ==\ntext\n"); test_page(get_page('headers'), '
  • one
  • ', '
  • two
  • ', '

    one

    ', '

    two

    ', ); remove_rule(\&TocRule); # headers only add_module('headers.pl'); update_page('headers', "is header\n=========\n\ntext\n"); test_page(get_page('headers'), '

    is header

    '); remove_rule(\&HeadersRule); # -------------------- print '[with portrait support]'; clear_pages(); add_module('portrait-support.pl'); # nothing update_page('headers', "[new]foo\n== no header ==\n\ntext\n"); test_page(get_page('headers'), '

    foo == no header ==

    text

    '); # usemod only add_module('usemod.pl'); update_page('headers', "[new]foo\n== is header ==\n\ntext\n"); test_page(get_page('headers'), '

    foo

    is header

    '); remove_rule(\&UsemodRule); # toc only add_module('toc.pl'); update_page('headers', "[new]foo\n== one ==\ntext\n== two ==\ntext\n== three ==\ntext\n"); test_page(get_page('headers'), '
  • one
  • ', '
  • two
  • ', '

    foo

    one

    ', '

    two

    ', ); remove_rule(\&TocRule); # headers only add_module('headers.pl'); update_page('headers', "[new]foo\nis header\n=========\n\ntext\n"); test_page(get_page('headers'), '

    foo

    is header

    '); remove_rule(\&HeadersRule); # portrait-support, toc, and usemod add_module('usemod.pl'); add_module('toc.pl'); update_page('headers', "[new]foo\n== one ==\ntext\n== two ==\ntext\n== three ==\ntext\n"); test_page(get_page('headers'), '
  • one
  • ', '
  • two
  • ', '

    foo

    one

    ', '

    two

    ', ); remove_rule(\&UsemodRule); remove_rule(\&TocRule); *GetHeader = *OldTocGetHeader; remove_rule(\&PortraitSupportRule); *ApplyRules = *OldPortraitSupportApplyRules; # -------------------- print '[hr in various modules]'; clear_pages(); # without portrait-support # nothing update_page('hr', "one\n----\ntwo\n"); test_page(get_page('hr'), 'one ---- two'); # usemod only add_module('usemod.pl'); update_page('hr', "one\n----\ntwo\n"); test_page(get_page('hr'), '

    one


    two

    '); remove_rule(\&UsemodRule); # headers only add_module('headers.pl'); update_page('hr', "one\n----\ntwo\n"); test_page(get_page('hr'), '

    one

    two

    '); update_page('hr', "one\n\n----\ntwo\n"); test_page(get_page('hr'), '

    one


    two

    '); remove_rule(\&HeadersRule); # -------------------- print '[with portrait support]'; clear_pages(); add_module('portrait-support.pl'); # just portrait-support update_page('hr', "[new]one\n----\ntwo\n"); test_page(get_page('hr'), '

    one


    two

    '); # usemod and portrait-support add_module('usemod.pl'); update_page('hr', "one\n----\ntwo\n"); test_page(get_page('hr'), '

    one


    two

    '); unlink('/tmp/oddmuse/modules/usemod.pl') or die "Cannot unlink: $!"; remove_rule(\&UsemodRule); # headers and portrait-support add_module('headers.pl'); update_page('hr', "one\n----\ntwo\n"); test_page(get_page('hr'), '

    one

    two

    '); update_page('hr', "one\n\n----\ntwo\n"); test_page(get_page('hr'), '

    one


    two

    '); unlink('/tmp/oddmuse/modules/headers.pl') or die "Cannot unlink: $!"; remove_rule(\&HeadersRule); remove_rule(\&PortraitSupportRule); *ApplyRules = *OldPortraitSupportApplyRules; # -------------------- fixme: print '[calendar]'; clear_pages(); my ($sec, $min, $hour, $mday, $mon, $year) = localtime($Now); $mon++; $year += 1900; my $year_next = $year +1; my $year_prev = $year -1; my $today = sprintf("%d-%02d-%02d", $year, $mon, $mday); $oday = $mday -1; $oday += 2 if $oday < 1; my $otherday = sprintf("%d-%02d-%02d", $year, $mon, $oday); add_module('calendar.pl'); test_page(get_page('action=calendar'), map { $_ = quotemeta; s|\\ \\\?| ?|g; $_; } '
    ', '
        ' # monthly collection
    	  . '',
    	  ' ?' . sprintf("%2d", $mday) . '',
    	  ' ?' . sprintf("%2d", $oday) . '',
    	  );
    
    update_page($today, "yadda");
    
    test_page(get_page('action=calendar'),
    	  map { $_ = quotemeta; s|\\ \\\?| ?|g; $_; }
    	  ' ?' . sprintf("%2d", $mday) . '');
    
    update_page("${today}_more", "more yadda");
    
    test_page(get_page('action=calendar'),
    	  map { $_=quotemeta; s|\\ \\\?| ?|g; $_; }
    	  ' ?' . sprintf("%2d", $mday) . '');
    
    remove_rule(\&CalendarRule);
    *GetHeader = *OldCalendarGetHeader;
    
    ### END OF TESTS
    
    print "\n";
    print "$passed passed, $failed failed.\n";