boinc/doc/test.php

241 lines
8.4 KiB
HTML

<? // -*- html -*-
require_once("docutil.php");
page_head("Testing BOINC");
?>
<h2>Python testing framework</h2>
The <code>test/</code> directory contains a library of Python modules that
make end-to-end testing of BOINC easy.
<h2>Quick start</h2>
Single test:
<blockquote>
<code> cd boinc/test && ./test_uc.py </code>
</blockquote>
Full test suite:
<blockquote>
<code> cd boinc/test && make check </code>
</blockquote>
After two or three minutes you should see "Passed Test". During the test you
should see various progress status indicators (Resize your window so that the
status indicator line fits on one line).
<h2>Goals of the testing framework</h2>
The goal of the framework is to support automated testing of BOINC itself, and
of BOINC applications. Each test is performed by a Python program that
initializes the system to a deterministic state, executes the system, detects
termination, and returns success or failure depending on the final state.
<p>
Many BOINC features involve multiple projects and/or multiple hosts. It would
be prohibitively complex to do automated testing on multiple physical hosts.
Fortunately the BOINC architecture makes it possible for multiple projects and
(virtual) hosts to reside on a single physical host. So the testing framework
uses this approach.
<p>
The framework lets you test systems with any of the following attributes:
<ul>
<li> Multiple projects
<li> Multiple applications per project
<li> Multiple participants per project
<li> Multiple hosts, with arbitrary enrollment in projects
</ul>
The following system attributes are planned but not implemented yet:
<ul>
<li> Multiple data servers or scheduling servers per project.
<li> Simulated failures of servers and network connections.
<li> Simulations of various host conditions
(out of disk space, crash/reboot, etc.).
</ul>
<h2>Software</h2>
<h3>Pre-requisites</h3>
<ol>
<li> <b>MySQL</b> installed and running with permissions for the test script
user to create databases. Currently the script expects it to be
running on localhost but that could be changed.
<li> <b>Python 2.2</b>, <a href=install_python_mysqldb.txt>Python module
MySQLdb</a>
</ol>
<h3>Other optional software</h3>
<ol>
<li> <b>PHPMyAdmin</b>: Useful for viewing database.
<li> <b>Apache</b> or other web server: normal the test system uses a custom
CGI/PHP web server based on the Python BaseHTTPServer module, but
a real web server could be used to test things like permissions and
throughput.
<li> <b>PHP</b>: Useful for viewing web server output, but not necessary
(otherwise a stub fake_php.py program is used)
</ol>
Note that a performance web server with PHP is required for running a real
server, but that requires a lot of path and permissions configuration so we
opt not to use them in testing.
<!-- TODO: Directory structure -->
<!-- TODO: Modules/ Classes -->
<!-- TODO: Example script -->
<h2>Test applications</h2>
The <code>apps</code> directory contains the following test applications:
<ul>
<li><code>upper_case</code>: converts a file to upper case.
<li><code>concat</code>: concatenates its input files.
<li><code>1sec</code>: uses 1 second of CPU time.
<li><code>uc_slow</code>: like upper_case, but processes only one character per
second. Checkpoints every 5 characters. Restartable.
</ul>
<h2>Test cases</h2>
The <code>test/</code> directory contains various python scripts named with
prefix <code>test_</code>. Each of these is a test case which runs an
end-to-end test of BOINC (creates directory structure for project(s) and
host(s), starts a web server, server daemons, host client(s), and checks
output is as expected).
<table border=1>
<tr><td><code>test_uc.py</code></td>
<td>The basic test using <code>uppercase</code></td></tr>
<tr><td><code>test_concat.py</code></td>
<td> tests command-line arguments and
filenames</tr>
<tr><td><code>test_uc_slow.py</code></td>
<td> tests checkpoint/restart mechanism</tr>
<tr><td><code>test_prefs.py</code></td>
<td> tests some aspects of preferences.</tr>
<tr><td><code>test_water.py</code></td>
<td> tests some aspects of water marks.</tr>
<tr><td><code>test_rsc.py</code></td>
<td> tests that scheduling server only sends
feasible work units.</tr>
<tr><td><code>test_pers.py</code></td>
<td> tests the persistent file transfers for
download and upload. It interrupts them in the middle and makes sure
that the filesize never decreases along interrupted transfers.</tr>
<tr><td><code>test_masterurl_failure.py</code></td>
<td> tests the exponential backoff
mechanism on the client in case of master IURL failures. This test is
not automated. It has to be run, and then client.out (in the host
directory) must be looked at to examine whether everything is working
correctly.</tr>
<tr><td><code>test_sched_failure.py</code></td>
<td>tests the exponential backoff mechanism
on the client in case of scheduling server failures.
This test is not automated.
It has to be run, and then client.out (in the host
directory) must be looked at to examine whether everything
is working correctly.</tr>
</table>
<h2>Appendix: Optional Environment Variables</h2>
The following environment variables are optional and apply whatever web server
you use:
<p>
<code>BOINC_TEST_USER_NAME</code>
<blockquote>
User name to use for setting up database name. Defaults to <code>$USER</code>
</blockquote>
<code>BOINC_TEST_VERBOSE</code>
<blockquote>
Verbosity level.
<table border=1>
<tr><td><code>0</code></td><td>print nothing</td></tr>
<tr><td><code>1</code> [default]</td><td>print some. if output is a tty, overwrite lines.</td>
<tr><td><code>2</code></td><td>print all</td>
</table>
</blockquote>
<code>BOINC_TEST_DELETE</code>
<blockquote>
Specifies whether or not to delete testbed after the test finishes. Only
relevant when BOINC_TEST_AUTO_SETUP=0. Possible values (case doesn't
matter):
<table border=1>
<tr><td><code>No</code></td></tr>
<tr><td><code>If-Successful</code> [default]</td></tr>
<tr><td><code>Always</code></td></tr>
</table>
</blockquote>
<code>BOINC_TEST_INSTALL_METHOD</code>
<blockquote>
Specifies how to install html/php, cgi from source directories to testbed
location.
<table border=1>
<tr><td><code>link</code> </td><td>hardlink</td></tr>
<tr><td><code>symlink</code> [default]</td><td>symbolic link</td></tr>
<tr><td><code>copy</code> </td><td>copy</td></tr>
</table>
Copying is useful because it preserves what version of the file was used
in a particular test run and hardlinking is best because compiled cgi and
scheduler programs are not disrupted by parallel builds.
</blockquote>
<h2>Appendix: Web Server</h2>
By default, the test script will use a custom web server that has no security
and minimal cgi/php capability. You can also use Apache or some other web
server with manually initialized directories by setting these environment
variables:
<blockquote>
<pre>
BOINC_TEST_AUTO_SETUP=0 [default=1]
BOINC_TEST_KEY_DIR
BOINC_TEST_PROJECTS_DIR
BOINC_TEST_CGI_URL
BOINC_TEST_HTML_URL
BOINC_TEST_CGI_DIR
BOINC_TEST_HTML_DIR
BOINC_TEST_HOSTS_DIR
</pre>
</blockquote>
<h3>Example setup</h3>
Bourne shell:
<pre>
QHOME=/disks/philmor/a/users/quarl/proj
TOP=$QHOME/test-boinc
URL=http://milhouse.ssl.berkeley.edu/quarl
export BOINC_TEST_PROJECTS_DIR=$TOP/projects
export BOINC_TEST_USER_NAME=quarl
export BOINC_TEST_SRC_DIR=$QHOME/boinc
export BOINC_TEST_CGI_DIR=$TOP/boinc_cgi
export BOINC_TEST_CGI_URL=$URL/boinc_cgi
export BOINC_TEST_HTML_DIR=$TOP/boinc_html
export BOINC_TEST_HTML_URL=$URL/boinc_html
export BOINC_TEST_SHMEM_KEY=0x1717f00f
export BOINC_TEST_KEY_DIR=$TOP/keys
export BOINC_TEST_HOSTS_DIR=$TOP/host
</pre>
Apache configuration:
<pre>
&lt;Directory /disks/philmor/a/users/quarl/proj/test-boinc&gt;
AllowOverride FileInfo AuthConfig Limit
Options Indexes SymLinksIfOwnerMatch IncludesNoExec ExecCGI
&lt;Limit GET POST OPTIONS PROPFIND&gt;
Order allow,deny
Allow from all
&lt;/Limit&gt;
&lt;/Directory&gt;
ScriptAlias /quarl/boinc_cgi/ "/disks/philmor/a/users/quarl/proj/test-boinc/boinc_cgi/"
Alias /quarl/ "/disks/philmor/a/users/quarl/proj/test-boinc/"
</pre>
<? page_tail(); ?>