|
|
|
Tests for Mediawiki-to-Git
|
|
|
|
==========================
|
|
|
|
|
|
|
|
Introduction
|
|
|
|
------------
|
|
|
|
This manual describes how to install the git-remote-mediawiki test
|
|
|
|
environment on a machine with git installed on it.
|
|
|
|
|
|
|
|
Prerequisite
|
|
|
|
------------
|
|
|
|
|
|
|
|
In order to run this test environment correctly, you will need to
|
|
|
|
install the following packages (Debian/Ubuntu names, may need to be
|
|
|
|
adapted for another distribution):
|
|
|
|
|
|
|
|
* lighttpd
|
|
|
|
* php5
|
|
|
|
* php5-cgi
|
|
|
|
* php5-cli
|
|
|
|
* php5-curl
|
|
|
|
* php5-sqlite
|
|
|
|
|
|
|
|
Principles and Technical Choices
|
|
|
|
--------------------------------
|
|
|
|
|
|
|
|
The test environment makes it easy to install and manipulate one or
|
|
|
|
several MediaWiki instances. To allow developers to run the testsuite
|
|
|
|
easily, the environment does not require root privilege (except to
|
|
|
|
install the required packages if needed). It starts a webserver
|
|
|
|
instance on the user's account (using lighttpd greatly helps for
|
|
|
|
that), and does not need a separate database daemon (thanks to the use
|
|
|
|
of sqlite).
|
|
|
|
|
|
|
|
Run the test environment
|
|
|
|
------------------------
|
|
|
|
|
|
|
|
Install a new wiki
|
|
|
|
~~~~~~~~~~~~~~~~~~
|
|
|
|
|
|
|
|
Once you have all the prerequisite, you need to install a MediaWiki
|
|
|
|
instance on your machine. If you already have one, it is still
|
|
|
|
strongly recommended to install one with the script provided. Here's
|
|
|
|
how to work it:
|
|
|
|
|
|
|
|
a. change directory to contrib/mw-to-git/t/
|
|
|
|
b. if needed, edit test.config to choose your installation parameters
|
|
|
|
c. run `./install-wiki.sh install`
|
|
|
|
d. check on your favourite web browser if your wiki is correctly
|
|
|
|
installed.
|
|
|
|
|
|
|
|
Remove an existing wiki
|
|
|
|
~~~~~~~~~~~~~~~~~~~~~~~
|
|
|
|
|
|
|
|
Edit the file test.config to fit the wiki you want to delete, and then
|
|
|
|
execute the command `./install-wiki.sh delete` from the
|
|
|
|
contrib/mw-to-git/t directory.
|
|
|
|
|
|
|
|
Run the existing tests
|
|
|
|
~~~~~~~~~~~~~~~~~~~~~~
|
|
|
|
|
|
|
|
The provided tests are currently in the `contrib/mw-to-git/t` directory.
|
|
|
|
The files are all the t936[0-9]-*.sh shell scripts.
|
|
|
|
|
|
|
|
a. Run all tests:
|
|
|
|
To do so, run "make test" from the contrib/mw-to-git/ directory.
|
|
|
|
|
|
|
|
b. Run a specific test:
|
|
|
|
To run a given test <test_name>, run ./<test_name> from the
|
|
|
|
contrib/mw-to-git/t directory.
|
|
|
|
|
|
|
|
How to create new tests
|
|
|
|
-----------------------
|
|
|
|
|
|
|
|
Available functions
|
|
|
|
~~~~~~~~~~~~~~~~~~~
|
|
|
|
|
|
|
|
The test environment of git-remote-mediawiki provides some functions
|
|
|
|
useful to test its behaviour. for more details about the functions'
|
|
|
|
parameters, please refer to the `test-gitmw-lib.sh` and
|
|
|
|
`test-gitmw.pl` files.
|
|
|
|
|
|
|
|
** `test_check_wiki_precond`:
|
|
|
|
Check if the tests must be skipped or not. Please use this function
|
|
|
|
at the beginning of each new test file.
|
|
|
|
|
|
|
|
** `wiki_getpage`:
|
|
|
|
Fetch a given page from the wiki and puts its content in the
|
|
|
|
directory in parameter.
|
|
|
|
|
|
|
|
** `wiki_delete_page`:
|
|
|
|
Delete a given page from the wiki.
|
|
|
|
|
|
|
|
** `wiki_edit_page`:
|
|
|
|
Create or modify a given page in the wiki. You can specify several
|
|
|
|
parameters like a summary for the page edition, or add the page to a
|
|
|
|
given category.
|
|
|
|
See test-gitmw.pl for more details.
|
|
|
|
|
|
|
|
** `wiki_getallpage`:
|
|
|
|
Fetch all pages from the wiki into a given directory. The directory
|
|
|
|
is created if it does not exists.
|
|
|
|
|
|
|
|
** `test_diff_directories`:
|
|
|
|
Compare the content of two directories. The content must be the same.
|
|
|
|
Use this function to compare the content of a git directory and a wiki
|
|
|
|
one created by wiki_getallpage.
|
|
|
|
|
|
|
|
** `test_contains_N_files`:
|
|
|
|
Check if the given directory contains a given number of file.
|
|
|
|
|
|
|
|
** `wiki_page_exists`:
|
|
|
|
Tests if a given page exists on the wiki.
|
|
|
|
|
|
|
|
** `wiki_reset`:
|
|
|
|
Reset the wiki, i.e. flush the database. Use this function at the
|
|
|
|
beginning of each new test, except if the test re-uses the same wiki
|
|
|
|
(and history) as the previous test.
|
|
|
|
|
|
|
|
How to write a new test
|
|
|
|
~~~~~~~~~~~~~~~~~~~~~~~
|
|
|
|
|
|
|
|
Please, follow the standards given by git. See git/t/README.
|
|
|
|
New file should be named as t936[0-9]-*.sh.
|
|
|
|
Be sure to reset your wiki regulary with the function `wiki_reset`.
|