# call this to declare that a unit test has passed
function unit_test_passed($msg) {
- if(isset($GLOBALS['unit_tests_verbose']) && $GLOBALS['unit_tests_verbose'] > 1) {
- message("PASSED: $msg");
- }
+ $GLOBALS['unit_tests_passed_msgs'][] = $msg;
$GLOBALS['unit_tests_passed'] += 1;
}
# call this to declare that a unit test has failed
function unit_test_failed($msg) {
- message("FAILED: $msg");
+ $GLOBALS['unit_tests_failed_msgs'][] = $msg;
$GLOBALS['unit_tests_failed'] += 1;
}
# tests in that file. It should print a message() about each test that failed,
# and return the number of tests that failed.
function run_unit_tests($directory, $basenames) {
+ $files = array();
$GLOBALS['unit_tests_passed'] = 0;
$GLOBALS['unit_tests_failed'] = 0;
$basenames = explode(' ', $basenames);
foreach($basenames as $basename) {
+ $GLOBALS['unit_tests_passed_msgs'] = array();
+ $GLOBALS['unit_tests_failed_msgs'] = array();
+ $already_passed = $GLOBALS['unit_tests_passed'];
+ $already_failed = $GLOBALS['unit_tests_failed'];
$filename = "$directory/$basename.php";
- message("running tests in $filename");
file_run_unit_tests($filename);
+ $files[] = array(
+ 'file' => $filename,
+ 'fails' => columnize($GLOBALS['unit_tests_failed_msgs']),
+ 'passes' => columnize($GLOBALS['unit_tests_passed_msgs']),
+ 'count_passed' => $GLOBALS['unit_tests_passed'] - $already_passed,
+ 'count_failed' => $GLOBALS['unit_tests_failed'] - $already_failed
+ );
}
$passed = $GLOBALS['unit_tests_passed'];
$failed = $GLOBALS['unit_tests_failed'];
- message("tests finished with $passed test" . enc_s($passed) . " passed and $GLOBALS[unit_tests_failed] test" . enc_s($failed) . " failed");
+ tem_set('unit_tests', array(
+ 'files' => $files,
+ 'total_passed' => $passed,
+ 'total_failed' => $failed
+ ));
}
# Call this to unit test wfpl. By default it tests everything, or you can pass