Development Guide
Writing Unit Tests
Writing Unit Tests
ILIAS supports unit testing with the PHPUnit testing framework. We highly recommend their excellent documentation that explains the basic ideas of unit testing, how PHPUnit works and how it is installed.
Configuration
After installing PHPUnit on your machine you need to configure ILIAS to work with it. The test cases are performed with an authenticated user in your ILIAS installation. The configuration determines which user is used to perform the test cases. You will find a configuration file template at:
Services/PHPUnit/config/cfg.phpunit.template.php
Make a copy at:
Services/PHPUnit/config/cfg.phpunit.php
Now change the file and provide a valid client ID, account ID, and username.
Please activate the developer mode in your
client.ini.php
when running PHPUnit tests.
Test Cases
Test classes should be located in a subdirectory test of your components directory.
[components/ILIAS]/[ComponentName]/test
E.g. the test classes for the Administration service are located at ILIAS/Administration/test
. The names for test class files should usually be derived from the application class they are written for.
[ApplicationClassName]Test.php
E.g. if you write test cases for a class ilSetting the test class file should be named ilSettingTest.php
.
The class should contain a method starting with "test" for each test case.
<?php
/*
+-----------------------------------------------------------------------------+
| ILIAS open source |
+-----------------------------------------------------------------------------+
| Copyright (c) 1998-2006 ILIAS open source, University of Cologne |
[...]
+-----------------------------------------------------------------------------+
*/
class ilSettingTest extends PHPUnit_Framework_TestCase
{
protected $backupGlobals = FALSE;
protected function setUp()
{
include_once("./Services/PHPUnit/classes/class.ilUnitUtil.php");
ilUnitUtil::performInitialisation();
}
public function testSetGetSettings()
{
$set = new ilSetting("test_module");
$set->set("foo", "bar");
$value = $set->get("foo");
$this->assertEquals("bar", $value);
}
[...]
}
?>
- Your test class must be derived from class PHPUnit_Framework_TestCase.
- Your test must be executable with PHPUnit 5.7.
- If your test needs an ILIAS Installation, it must be annotated with @group needsInstalledILIAS, and...
- you must set $backupGlobals to false, otherwise, your test cases will not work.
- the setUp() method should contain the ilUnitUtil::performInitialisation(); call. ilUnitUtil can be found in Services/PHPUnit/classes.
- If your test does not need an ILIAS Installation, it must not be annotated with @group needsInstalledILIAS and also should not use ilUnitUtil::performInitialisation().
To run your test class you simply call phpunit in your ILIAS root directory with the local path of your test class (omit the .php suffix):
> phpunit components/ILIAS/Administration/test/ilSettingTest
- Please write your test cases in a way that the requirements to run them are minimal. The test cases should run on a usual system. They should not require that certain conditions are given on the test system, e.g. an empty repository.
- Clean up the data that is written during the test case. If possible, a test run should not leave any data created during the test in the system.
Test Suites
Test suites allow to perform aggregated tests. They should be provided on the component level, one test suite for each service and module. The file name must follow the format:
il[components/ILIAS][ComponentName]Suite.php
E.g. the test suite class for the Administration service is located at:
ILIAS/Administration/test/ilServicesAdministrationSuite.php
The class is named:
ilServicesAdministrationSuite
<?php
/*
+-----------------------------------------------------------------------------+
| ILIAS open source |
+-----------------------------------------------------------------------------+
| Copyright (c) 1998-2009 ILIAS open source, University of Cologne |
[...]
+-----------------------------------------------------------------------------+
*/
class ilServicesAdministrationSuite extends PHPUnit_Framework_TestSuite
{
public static function suite()
{
$suite = new ilServicesAdministrationSuite();
// add each test class of the component
include_once("./components/ILIAS/Administration/test/ilSettingTest.php");
$suite->addTestSuite("ilSettingTest");
[...]
return $suite;
}
}
?>
The example outlines the basic structure of a test suite class. To run the test suite, simply pass the class name to phpunit in the ILIAS main directory:
> phpunit components/ILIAS/Administration/test/ilServicesAdministrationSuite
The Global Test Suite
The global test suite scans all Services and Modules directory automatically for component level test suites and aggregates them to one big test suite. The suite is located in the PHPUnit Service. You can run the suite by typing:
> phpunit Services/PHPUnit/test/ilGlobalSuite
The global suite will first list all component suites that are included in execution. If your suite is not listed, you should check whether your suite file and class is following the naming conventions as written in the previous section.