Alex Schroeder eaa9108845 test.pl: move to encode_utf8 as well il y a 8 ans
..
feeds 0db6f8e731 Moved ln.txt to the testing feeds il y a 9 ans
README 57ab7ad761 Note that sometimes it is necessary to run InitVariables after il y a 15 ans
aggregate.t c4671a8909 Removing clear_pages() from the beginning of tests (part 1) il y a 9 ans
all.t 77fd49544c all.t: test for monolithic links of images il y a 9 ans
ampersand.t eb3071d0db Removing clear_pages() from the beginning of tests (part 2) il y a 9 ans
anchors.t c4671a8909 Removing clear_pages() from the beginning of tests (part 1) il y a 9 ans
askpage.t 71ff0f7de3 askpage.t: new il y a 9 ans
atom.t 241a88ef48 Move server starting code from atom.t to test.pl il y a 8 ans
ban-contributors.t c4671a8909 Removing clear_pages() from the beginning of tests (part 1) il y a 9 ans
ban-quick-editors.t 59e79d2b17 Summary: Fix bug in NewText il y a 9 ans
ban.t ee52a25ebf ban.t: fix number of tests il y a 9 ans
bbcode.t c4671a8909 Removing clear_pages() from the beginning of tests (part 1) il y a 9 ans
big-brother.t 33a3f515a3 big-brother.t: more rebust under heavy load il y a 9 ans
cache.t d5fda299b0 Some tests now more rebust under heavy load il y a 9 ans
calendar.t c4671a8909 Removing clear_pages() from the beginning of tests (part 1) il y a 9 ans
clusters.t 9636fe2e0a Various tests fixed il y a 9 ans
comments.t 4d8b028e2d test for wiping comments with "0" and fix il y a 9 ans
config-page.t 1255fe8168 Updated tests for ad/spans-and-divs branch. il y a 10 ans
conflict.t 2517928c1e conflict.t: typo il y a 9 ans
contributors.t c4671a8909 Removing clear_pages() from the beginning of tests (part 1) il y a 9 ans
cookie.t 79610f7490 cookie.t: fix tests il y a 9 ans
creole.t 9636fe2e0a Various tests fixed il y a 9 ans
creoleaddition.t c4671a8909 Removing clear_pages() from the beginning of tests (part 1) il y a 9 ans
crossbar.t e731c16214 Fix crossbar.t after 858ff72 il y a 9 ans
crumbs.t c4671a8909 Removing clear_pages() from the beginning of tests (part 1) il y a 9 ans
css.t 69fcb9646b Fix tests for default stylesheet link il y a 9 ans
default-links.t 874586f27d default-links.t: fix tests il y a 9 ans
default-markup.t 66ea19a686 default-markup.t: fix tests il y a 9 ans
despam.t c4671a8909 Removing clear_pages() from the beginning of tests (part 1) il y a 9 ans
diff.t eb3071d0db Removing clear_pages() from the beginning of tests (part 2) il y a 9 ans
dotfiles.t c4671a8909 Removing clear_pages() from the beginning of tests (part 1) il y a 9 ans
download.t c4671a8909 Removing clear_pages() from the beginning of tests (part 1) il y a 9 ans
drafts.t eb3071d0db Removing clear_pages() from the beginning of tests (part 2) il y a 9 ans
duckduckgo-search.t c4671a8909 Removing clear_pages() from the beginning of tests (part 1) il y a 9 ans
dynamic-comments.t eb3071d0db Removing clear_pages() from the beginning of tests (part 2) il y a 9 ans
edit-paragraphs.t eb3071d0db Removing clear_pages() from the beginning of tests (part 2) il y a 9 ans
edit.t c4671a8909 Removing clear_pages() from the beginning of tests (part 1) il y a 9 ans
emailquote.t c4671a8909 Removing clear_pages() from the beginning of tests (part 1) il y a 9 ans
enclosure.t c4671a8909 Removing clear_pages() from the beginning of tests (part 1) il y a 9 ans
encoding.t 93cc1578d0 encoding.t: fix test il y a 9 ans
fieldlist.t c4671a8909 Removing clear_pages() from the beginning of tests (part 1) il y a 9 ans
find.t c4671a8909 Removing clear_pages() from the beginning of tests (part 1) il y a 9 ans
fix-encoding.t eb3071d0db Removing clear_pages() from the beginning of tests (part 2) il y a 9 ans
footer.t c4671a8909 Removing clear_pages() from the beginning of tests (part 1) il y a 9 ans
git.t 994b4e8051 Tests rely on English output il y a 8 ans
google-custom-search.t c4671a8909 Removing clear_pages() from the beginning of tests (part 1) il y a 9 ans
google-plus-one.t c4671a8909 Removing clear_pages() from the beginning of tests (part 1) il y a 9 ans
google-search.t c4671a8909 Removing clear_pages() from the beginning of tests (part 1) il y a 9 ans
gotobar.t eb3071d0db Removing clear_pages() from the beginning of tests (part 2) il y a 9 ans
gravatar.t 9fbf8a6f39 Use @MyFormChanges in mail.pl il y a 9 ans
headers.t c4671a8909 Removing clear_pages() from the beginning of tests (part 1) il y a 9 ans
history.t 971f4b1579 history.t: Fix for $KeepDays = 0 il y a 9 ans
hr.t c4671a8909 Removing clear_pages() from the beginning of tests (part 1) il y a 9 ans
htmlcomment.t c4671a8909 Removing clear_pages() from the beginning of tests (part 1) il y a 9 ans
image.t eb3071d0db Removing clear_pages() from the beginning of tests (part 2) il y a 9 ans
include.t c4671a8909 Removing clear_pages() from the beginning of tests (part 1) il y a 9 ans
irc.t c4671a8909 Removing clear_pages() from the beginning of tests (part 1) il y a 9 ans
journal-rss.t c4671a8909 Removing clear_pages() from the beginning of tests (part 1) il y a 9 ans
journal.t c4671a8909 Removing clear_pages() from the beginning of tests (part 1) il y a 9 ans
journal2.t c4671a8909 Removing clear_pages() from the beginning of tests (part 1) il y a 9 ans
journal3.t c4671a8909 Removing clear_pages() from the beginning of tests (part 1) il y a 9 ans
languages.t 67650e3dc8 More UTF-8 fixes il y a 12 ans
like.t c4671a8909 Removing clear_pages() from the beginning of tests (part 1) il y a 9 ans
link-all.t c4671a8909 Removing clear_pages() from the beginning of tests (part 1) il y a 9 ans
links.t 81721e29de links.t: GPLv3 and copyright year il y a 9 ans
listlocked.t c4671a8909 Removing clear_pages() from the beginning of tests (part 1) il y a 9 ans
load-lang.t d5429d276f load-lang.pl: Fix code and add test il y a 8 ans
localnames.t 5e35d0aa79 localnames.t: fix tests il y a 9 ans
lock-expiration.t c4671a8909 Removing clear_pages() from the beginning of tests (part 1) il y a 9 ans
lock-on-creation.t c4671a8909 Removing clear_pages() from the beginning of tests (part 1) il y a 9 ans
lock.t 3b6d891dc7 Stop leaving locks behind il y a 9 ans
logbannedcontent.t c4671a8909 Removing clear_pages() from the beginning of tests (part 1) il y a 9 ans
macros.t c4671a8909 Removing clear_pages() from the beginning of tests (part 1) il y a 9 ans
mail.t c4671a8909 Removing clear_pages() from the beginning of tests (part 1) il y a 9 ans
maintain.t 0322deaf82 maintain.t: Fix for $KeepDays = 0 il y a 9 ans
major.t e25a621e6e Big changes to how diffs are generated il y a 9 ans
markdown-rule.t c4671a8909 Removing clear_pages() from the beginning of tests (part 1) il y a 9 ans
markup-and-creole.t c4671a8909 Removing clear_pages() from the beginning of tests (part 1) il y a 9 ans
markup.t c4671a8909 Removing clear_pages() from the beginning of tests (part 1) il y a 9 ans
merge.t 90829ca433 Removing clear_pages() from the beginning of tests (part 3) il y a 9 ans
meta-data.t c4671a8909 Removing clear_pages() from the beginning of tests (part 1) il y a 9 ans
meta.t 725e121731 meta.t: perl -c only takes one file il y a 9 ans
moin.t c4671a8909 Removing clear_pages() from the beginning of tests (part 1) il y a 9 ans
mojolicious-namespaces.t 0a77bd0b47 All access to the file system needs bytes! il y a 8 ans
mojolicious.t 8e73f6f0dd Use /wiki in $ScriptName for Mojolicious test il y a 8 ans
multi-url-spam-block.t c4671a8909 Removing clear_pages() from the beginning of tests (part 1) il y a 9 ans
namespaces-2.2.6.pl 68e71cc535 upgrade.t: fixed old namespaces problem il y a 10 ans
namespaces.t aa8dcd54fa namespaces.t: fix copyright year il y a 9 ans
near-links.t 6589e84d10 near-links.t fix test for empty page il y a 9 ans
new.t 6207434f19 Make sure the "Welcome!" message is shown il y a 9 ans
oddmuse-2.2.6.pl 0ba76bafb2 oddmuse-2.2.6.pl: use $q->end_form il y a 9 ans
org-mode.t c4671a8909 Removing clear_pages() from the beginning of tests (part 1) il y a 9 ans
page-trail.t c4671a8909 Removing clear_pages() from the beginning of tests (part 1) il y a 9 ans
pagenames.t c4671a8909 Removing clear_pages() from the beginning of tests (part 1) il y a 9 ans
password.t c4671a8909 Removing clear_pages() from the beginning of tests (part 1) il y a 9 ans
permanent-anchors.t eb3071d0db Removing clear_pages() from the beginning of tests (part 2) il y a 9 ans
portrait-support.t c4671a8909 Removing clear_pages() from the beginning of tests (part 1) il y a 9 ans
preview.t c0f0b970a6 preview.pl: Add admin menu il y a 9 ans
private-pages.t c4671a8909 Removing clear_pages() from the beginning of tests (part 1) il y a 9 ans
private-wiki.t c4671a8909 Removing clear_pages() from the beginning of tests (part 1) il y a 9 ans
pygmentize.t 648e6eb9bc Skip pygmentize if the binary is not found il y a 8 ans
questionasker.t 89fa22d1c9 Introducing @MyFormChanges il y a 9 ans
questionmark.t c4671a8909 Removing clear_pages() from the beginning of tests (part 1) il y a 9 ans
raw.t c4671a8909 Removing clear_pages() from the beginning of tests (part 1) il y a 9 ans
rc-pagination.t c4671a8909 Removing clear_pages() from the beginning of tests (part 1) il y a 9 ans
rc.t 3ea87c007d The parameter days must be numeric il y a 9 ans
recaptcha.t b0f9722857 recaptcha.t: use Captcha::reCAPTCHA always il y a 9 ans
redirection.t eb3071d0db Removing clear_pages() from the beginning of tests (part 2) il y a 9 ans
referrer-tracking.t 9ec075c1c0 referrer-tracking.t switching to HTTPS il y a 9 ans
revisions.t e25a621e6e Big changes to how diffs are generated il y a 9 ans
rollback-extras.t 90829ca433 Removing clear_pages() from the beginning of tests (part 3) il y a 9 ans
rollback.t 755010f619 rollback.t: Fix tests given $KeepDays default il y a 9 ans
rss.t d32ebaddc8 rss.t: XSS in summaries was fixed il y a 9 ans
search-tag.t c4671a8909 Removing clear_pages() from the beginning of tests (part 1) il y a 9 ans
search.t 986e4fc65f Replace: no pagination il y a 9 ans
searchtags.t c4671a8909 Removing clear_pages() from the beginning of tests (part 1) il y a 9 ans
security.t c4671a8909 Removing clear_pages() from the beginning of tests (part 1) il y a 9 ans
server.t fdf0c2711b Added a test for stuff/server.pl il y a 8 ans
setext.t c4671a8909 Removing clear_pages() from the beginning of tests (part 1) il y a 9 ans
setup.pl 6372907c4b Parallelize tests il y a 9 ans
sidebar.t 755f742088 sidebar.t: writing more tests il y a 9 ans
simple-rules.t c4671a8909 Removing clear_pages() from the beginning of tests (part 1) il y a 9 ans
sitemap.t c4671a8909 Removing clear_pages() from the beginning of tests (part 1) il y a 9 ans
static-copy.t 8a36970b24 static-copy.pl: Fix non-ascii links il y a 9 ans
subscriberc.t c4671a8909 Removing clear_pages() from the beginning of tests (part 1) il y a 9 ans
summary.t c031898184 summary.t: XSS in summaries was fixed il y a 9 ans
surge-protection.t c4671a8909 Removing clear_pages() from the beginning of tests (part 1) il y a 9 ans
tables-long.t c4671a8909 Removing clear_pages() from the beginning of tests (part 1) il y a 9 ans
tables.t c4671a8909 Removing clear_pages() from the beginning of tests (part 1) il y a 9 ans
tags.t eb3071d0db Removing clear_pages() from the beginning of tests (part 2) il y a 9 ans
test.pl eaa9108845 test.pl: move to encode_utf8 as well il y a 8 ans
tex.t eb3071d0db Removing clear_pages() from the beginning of tests (part 2) il y a 9 ans
toc.t eb3071d0db Removing clear_pages() from the beginning of tests (part 2) il y a 9 ans
translation-links.t eb3071d0db Removing clear_pages() from the beginning of tests (part 2) il y a 9 ans
translations.t eb3071d0db Removing clear_pages() from the beginning of tests (part 2) il y a 9 ans
upgrade-files.t a8b7b67efe Use warnings il y a 9 ans
upgrade.t c4671a8909 Removing clear_pages() from the beginning of tests (part 1) il y a 9 ans
upload.t 57c2413b51 upload.t: add some explanations to the tests il y a 9 ans
usemod-1.0.4.pl f4e551111a Executable flag is only useful when shebang is specified il y a 10 ans
usemod-options.t c4671a8909 Removing clear_pages() from the beginning of tests (part 1) il y a 9 ans
usemod.t 9d3b5e25ee usemod.pl: fix XSS vulnerability for $HtmlLinks il y a 9 ans
weblog-3.t c4671a8909 Removing clear_pages() from the beginning of tests (part 1) il y a 9 ans
xss.t bc6ae67a9a xss.t: testing search & replace il y a 9 ans

README



Writing Tests
=============

Here's how to write tests.

1. Create a new file in the t directory, called foo.t. Start with
the following lines:

require 't/test.pl';
package OddMuse;
use Test::More tests => $num
clear_pages();

This will load the testing library, make all its functions
available to you, announce that you plan to make $num tests, and
clear all the pages from the test wiki.

The test wiki will be created in /tmp/oddmuse.

2. The wiki is accessed via the command line only. You don't need to
have your code installed on a webserver! Just run the test from
the parent directory:

perl t/foo.t

3. Write $num tests. :)

4. To examine the situation after having run some tests, you can
also call the script from the command line. The only problem is
that the tests use a specific data directory that you need to
provide via an environment variable:

WikiDataDir=test-data perl wiki.pl action=index raw=1

add_module, remove_module, and remove_rule
------------------------------------------

Load a module before you run any tests:

add_module('usemod.pl');

If the module has important setup code, you might have to add the
following:

InitVariables();

The reason is this: If you add a module and the run the script
again, you're fine. But if you run tests that don't invoke another
copy of the script, then the init code will not have run.

Modules and rules need rarely be removed, since every *.t file
starts in a new process. If you then want to run additional tests
without the module you added (in the same *.t file!), then remove
both the module and the rules it added. You'll have to do this
manually, unfortunately.

remove_module('usemod.pl');
remove_rule(\&UsemodRule);



update_page
-----------

$page = update_page($pagename, $content);
update_page($pagename, $content, $summary, $minor, $admin, @rest);

@rest is a list of parameter=value string pairs:

@rest = ('username=joe', 'ns=Moore');

If updating the page resultet in a redirect, the redirect is stored
in the variable $redirect, and you still get the result page
returned.

test_page($redirect, split('\n',<<'EOT'));
banned text
wiki administrator
matched
See .*BannedContent.* for more information
EOT

You can even create pages containing file uploads directly:

$page = update_page('alex pic', "#FILE image/png\niVBORw0KGgoAAAA");


get_page
--------

$page = get_page('action=calendar');
$page = get_page('action=rc all=1 showedit=1');
$page = get_page('action=rc', 'all=1', 'showedit=1');
test_page(get_page('action=all'),
'restricted to administrators');

Return the text of the page. The parameters are the parameters
available to you from the command line when using the CGI library:

keyword1 keyword2 keyword3
keyword1+keyword2+keyword3
name1=value1 name2=value2
name1=value1&name2=value2
"name1='I am a long value'" "name2=two\ words"
/your/path/here?name1=value1&name2=value2



run_tests
---------

Takes a list of alternating input and output strings, applies rules
(and thus @MyRules) to input and compares it to the output. If you
have html attributes in the output you want to test, use
xpath_run_tests, because the order of the attributes is not
guaranteed and varies with CGI library version.

run_tests(q{"Get lost!", they say.},
q{“Get lost!”, they say.});

run_tests(split('\n', <<'EOT'));
input1
output1
input2
output2
EOT

Newline excapes \n in the input and output are translated to real
newlines when running the tests.

run_tests(split('\n',<<'EOT'));
* ''one\n** two
  • one
    • two

EOT



test_page and test_page_negative
--------------------------------

Tests any string for regular expression matches:

test_page($string, $regexp1, $regexp2, ...);
test_page(update_page($pagename, $content), $re1, $re2);

Or make sure that none of the regular expressions match:

test_page_negative($page,
"rollback",
"Rollback",
"EvilPage",
"AnotherEvilPage",
);



xpath_run_tests
---------------

This is the equivalent of run_tests using XPath instead of simple
string comparison. It takes a list of alternating input and xpath
tests, applies rules (and thus @MyRules) to the input and applies
the test to the output.

xpath_run_tests(split('\n',<<'EOT'));
WikiWord
//a[@class="edit"][@title="Click to edit this page"]
This is a [:day for fun and laughter].
//a[@class="anchor"][@name="day_for_fun_and_laughter"]
EOT

XPath is harder to write, but is ideal when the output contains tags
with more than one attribute, since the order of attributes is
undefined. And you don't even have to test for all the attributes.



xpath_test and negative_xpath_test
----------------------------------

The equivalent of test_page, but using xpath instead of exact
matches.


xpath_test(get_page('action=all pwd=foo'),
'//p/a[@href="#HomePage"][text()="HomePage"]',
'//h1/a[@name="foo"][text()="foo"]',
'//a[@class="local"][@href="#bar"][text()="bar"]',
'//h1/a[@name="bar"][text()="bar"]')

And the same thing for negative matches, of course:

negative_xpath_test($page, '//h1/a[not(text())]');


run_macro_tests
---------------

run_macro_tests(split('\n',<<'EOT'));
$input1
$output2
$input2
$output2
EOT

Tests @MyMacros.