JasonWoof Got questions, comments, patches, etc.? Contact Jason Woofenden
add unit_test_func(), convert unit_tests/format.php to use it
authorJason Woofenden <jason@jasonwoof.com>
Mon, 12 Apr 2010 01:27:06 +0000 (21:27 -0400)
committerJason Woofenden <jason@jasonwoof.com>
Mon, 12 Apr 2010 01:27:06 +0000 (21:27 -0400)
unit_tests.php
unit_tests/format.php

index 97df911..d092962 100644 (file)
 require_once('code/wfpl/template.php');
 require_once('code/wfpl/messages.php');
 
+# 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'] += 1;
+}
+
+# call this to declare that a unit test has failed
+function unit_test_failed($msg) {
+       message("FAILED: $msg");
+       $GLOBALS['unit_tests_failed'] += 1;
+}
+
+# use this function to unit-test a function
+# real prototype: ($name, $args..., $correct)
+function unit_test_func() {
+       $args = func_get_args();
+       $function = array_shift($args);
+       $correct = array_pop($args);
+       $result = call_user_func_array($function, $args);
+       $message = "$function(" . join(', ', $args) . ") returned $result";
+       if($result == $correct) {
+               unit_test_passed($message);
+       } else {
+               unit_test_failed($message . " instead of $correct");
+       }
+}
+
+
 function file_run_unit_tests($filename) {
        require_once($filename);
        $func = basename($filename, '.php') . '_unit_tests_main';
@@ -36,14 +66,17 @@ function file_run_unit_tests($filename) {
 # 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) {
-       $errors = 0;
+       $GLOBALS['unit_tests_passed'] = 0;
+       $GLOBALS['unit_tests_failed'] = 0;
        $basenames = explode(' ', $basenames);
        foreach($basenames as $basename) {
                $filename = "$directory/$basename.php";
                message("running tests in $filename");
-               $errors += file_run_unit_tests($filename);
+               file_run_unit_tests($filename);
        }
-       message("tests finished with $errors error" . enc_s($errors));
+       $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");
 }
 
 # Call this to unit test wfpl. By default it tests everything, or you can pass
index dac002d..0869a7e 100644 (file)
 
 require_once('code/wfpl/format.php');
 
-function _test_format_money($input, $dollars_correct, $money_correct) {
-       $errors = 0;
-       $dollars = format_dollars($input);
-       $money = format_money($input);
-       if($dollars != $dollars_correct) {
-               ++$errors;
-               message("format_dollars(\"$input\") returned \"$dollars\" instead of \"$dollars_correct\"");
-       }
-       if($money != $money_correct) {
-               ++$errors;
-               message("format_money(\"$input\") returned \"$money\" instead of \"$money_correct\"");
-       }
-
-       return $errors;
+function _test_format_money($arg, $dollars_correct, $money_correct) {
+       unit_test_func('format_dollars', $arg, $dollars_correct);
+       unit_test_func('format_money', $arg, $money_correct);
 }
 
 function test_format_money() {
-       $errors = 0;
-       $errors += _test_format_money('1', '$1', '$1.00');
-       $errors += _test_format_money('0', '$0', '$0.00');
-       $errors += _test_format_money('0.0', '$0', '$0.00');
-       $errors += _test_format_money('0.00', '$0', '$0.00');
-       $errors += _test_format_money('00.00', '$0', '$0.00');
-       $errors += _test_format_money('0.000', '$0', '$0.00');
-       $errors += _test_format_money('0000.00000', '$0', '$0.00');
-       $errors += _test_format_money('0.01', '$0', '$0.01');
-       $errors += _test_format_money('0.51', '$1', '$0.51');
-       $errors += _test_format_money('2.05', '$2', '$2.05');
-       $errors += _test_format_money('2.10000500', '$2', '$2.10');
-       $errors += _test_format_money('2.005', '$2', '$2.01');
-       $errors += _test_format_money('2.004', '$2', '$2.00');
-       $errors += _test_format_money('2.1', '$2', '$2.10');
-       $errors += _test_format_money('2.0', '$2', '$2.00');
-       $errors += _test_format_money('1000', '$1,000', '$1,000.00');
-       $errors += _test_format_money('10000000', '$10,000,000', '$10,000,000.00');
-       $errors += _test_format_money('100000000000', '$100,000,000,000', '$100,000,000,000.00');
-       $errors += _test_format_money('1.99', '$2', '$1.99');
-       $errors += _test_format_money('1.555', '$2', '$1.56');
-       $errors += _test_format_money('19.555', '$20', '$19.56');
-       $errors += _test_format_money('9.499', '$9', '$9.50');
-       $errors += _test_format_money('9.989', '$10', '$9.99');
-       $errors += _test_format_money('9.999', '$10', '$10.00');
-       $errors += _test_format_money('19999999999.555', '$20,000,000,000', '$19,999,999,999.56');
-       return $errors;
+       _test_format_money('1', '$1', '$1.00');
+       _test_format_money('0', '$0', '$0.00');
+       _test_format_money('0.0', '$0', '$0.00');
+       _test_format_money('0.00', '$0', '$0.00');
+       _test_format_money('00.00', '$0', '$0.00');
+       _test_format_money('0.000', '$0', '$0.00');
+       _test_format_money('0000.00000', '$0', '$0.00');
+       _test_format_money('0.01', '$0', '$0.01');
+       _test_format_money('0.51', '$1', '$0.51');
+       _test_format_money('2.05', '$2', '$2.05');
+       _test_format_money('2.10000500', '$2', '$2.10');
+       _test_format_money('2.005', '$2', '$2.01');
+       _test_format_money('2.004', '$2', '$2.00');
+       _test_format_money('2.1', '$2', '$2.10');
+       _test_format_money('2.0', '$2', '$2.00');
+       _test_format_money('1000', '$1,000', '$1,000.00');
+       _test_format_money('10000000', '$10,000,000', '$10,000,000.00');
+       _test_format_money('100000000000', '$100,000,000,000', '$100,000,000,000.00');
+       _test_format_money('1.99', '$2', '$1.99');
+       _test_format_money('1.555', '$2', '$1.56');
+       _test_format_money('19.555', '$20', '$19.56');
+       _test_format_money('9.499', '$9', '$9.50');
+       _test_format_money('9.989', '$10', '$9.99');
+       _test_format_money('9.999', '$10', '$10.00');
+       _test_format_money('19999999999.555', '$20,000,000,000', '$19,999,999,999.56');
 }
 
-# returns number of errors
-function _test_format_misc($name, $arg, $correct) {
-       $function = "format_$name";
-       $ret = $function($arg);
-       if($ret !== $correct) {
-               message("$function($arg) returned \"$ret\" instead of \"$correct\"");
-               return 1;
-       }
-       return 0;
-}
 
 # run tests where int, int_0, decimal, positive_decimal should return the same result
 function _test_format_int($arg, $correct) {
@@ -87,102 +64,104 @@ function _test_format_int($arg, $correct) {
        } else {
                $correct_0 = $correct;
        }
-       $errons = 0;
-       $errors += _test_format_misc('int', $arg, $correct);
-       $errors += _test_format_misc('int_0', $arg, $correct_0);
-       $errors += _test_format_misc('positive_decimal', $arg, $correct);
-       $errors += _test_format_misc('decimal', $arg, $correct);
-       return $errors;
+       unit_test_func('format_int', $arg, $correct);
+       unit_test_func('format_int_0', $arg, $correct_0);
+       unit_test_func('format_positive_decimal', $arg, $correct);
+       unit_test_func('format_decimal', $arg, $correct);
 }
 
 # returns number of errors
 function test_format_misc() {
-       $errors = 0;
-
-       $errors += _test_format_misc('caption', 'something', 'Something');
-       $errors += _test_format_misc('caption', 'two_words', 'Two Words');
-       $errors += _test_format_misc('caption', 'email_special_case', 'E-mail Special Case');
-       $errors += _test_format_misc('caption', 'BIG', 'BIG');
-       $errors += _test_format_misc('caption', '1,2.3%^&', '1,2.3%^&');
+       unit_test_func('format_caption', 'something', 'Something');
+       unit_test_func('format_caption', 'two_words', 'Two Words');
+       unit_test_func('format_caption', 'email_special_case', 'E-mail Special Case');
+       unit_test_func('format_caption', 'BIG', 'BIG');
+       unit_test_func('format_caption', '1,2.3%^&', '1,2.3%^&');
 
        # test int, int_0, positive_decimal, decimal
-       $errors += _test_format_int('', '');
-       $errors += _test_format_int('abcdef', '');
-       $errors += _test_format_int('0', '0');
-       $errors += _test_format_int('00', '0');
-       $errors += _test_format_int('0000', '0');
-       $errors += _test_format_int('1', '1');
-       $errors += _test_format_int('100000000000000000000000000', '100000000000000000000000000');
-       $errors += _test_format_int('10000 0000000000000000000000', '100000000000000000000000000');
-       $errors += _test_format_int(' 1a2b3c%^&', '123');
+       _test_format_int('', '');
+       _test_format_int('abcdef', '');
+       _test_format_int('0', '0');
+       _test_format_int('00', '0');
+       _test_format_int('0000', '0');
+       _test_format_int('1', '1');
+       _test_format_int('100000000000000000000000000', '100000000000000000000000000');
+       _test_format_int('10000 0000000000000000000000', '100000000000000000000000000');
+       _test_format_int(' 1a2b3c%^&', '123');
        
-       $errors += _test_format_misc('int', '-1', '1');
-       $errors += _test_format_misc('int', '+1', '1');
-       $errors += _test_format_misc('int_0', '-1', '1');
-       $errors += _test_format_misc('int_0', '+1', '1');
-       $errors += _test_format_misc('positive_decimal', '-1', '1');
-       $errors += _test_format_misc('positive_decimal', '+1', '1');
-       $errors += _test_format_misc('decimal', '-1', '-1');
-       $errors += _test_format_misc('decimal', '+1', '1');
-
-       $errors += _test_format_misc('int', '-1.0', '1');
-       $errors += _test_format_misc('int', '+1.0', '1');
-       $errors += _test_format_misc('int_0', '-1.0', '1');
-       $errors += _test_format_misc('int_0', '+1.0', '1');
-       $errors += _test_format_misc('positive_decimal', '-1.0', '1.0');
-       $errors += _test_format_misc('positive_decimal', '+1.0', '1.0');
-       $errors += _test_format_misc('decimal', '-1.0', '-1.0');
-       $errors += _test_format_misc('decimal', '+1.0', '1.0');
-
-       $errors += _test_format_misc('positive_decimal', '1.0', '1.0');
-       $errors += _test_format_misc('decimal', '1.0', '1.0');
+       unit_test_func('format_int', '-1', '1');
+       unit_test_func('format_int', '+1', '1');
+       unit_test_func('format_int_0', '-1', '1');
+       unit_test_func('format_int_0', '+1', '1');
+       unit_test_func('format_positive_decimal', '-1', '1');
+       unit_test_func('format_positive_decimal', '+1', '1');
+       unit_test_func('format_decimal', '-1', '-1');
+       unit_test_func('format_decimal', '+1', '1');
+
+       unit_test_func('format_int', '-1.0', '1');
+       unit_test_func('format_int', '+1.0', '1');
+       unit_test_func('format_int_0', '-1.0', '1');
+       unit_test_func('format_int_0', '+1.0', '1');
+       unit_test_func('format_positive_decimal', '-1.0', '1.0');
+       unit_test_func('format_positive_decimal', '+1.0', '1.0');
+       unit_test_func('format_decimal', '-1.0', '-1.0');
+       unit_test_func('format_decimal', '+1.0', '1.0');
+
+       unit_test_func('format_positive_decimal', '1.0', '1.0');
+       unit_test_func('format_decimal', '1.0', '1.0');
 
        # extra zeros after the decimal point
-       $errors += _test_format_misc('positive_decimal', '-1.00', '1.0');
-       $errors += _test_format_misc('positive_decimal', '+1.00', '1.0');
-       $errors += _test_format_misc('decimal', '-1.00', '-1.0');
-       $errors += _test_format_misc('decimal', '+1.00', '1.0');
-       $errors += _test_format_misc('positive_decimal', '-1.000', '1.0');
-       $errors += _test_format_misc('positive_decimal', '+1.000', '1.0');
-       $errors += _test_format_misc('decimal', '-1.000', '-1.0');
-       $errors += _test_format_misc('decimal', '+1.000', '1.0');
+       unit_test_func('format_positive_decimal', '-1.00', '1.0');
+       unit_test_func('format_positive_decimal', '+1.00', '1.0');
+       unit_test_func('format_decimal', '-1.00', '-1.0');
+       unit_test_func('format_decimal', '+1.00', '1.0');
+       unit_test_func('format_positive_decimal', '-1.000', '1.0');
+       unit_test_func('format_positive_decimal', '+1.000', '1.0');
+       unit_test_func('format_decimal', '-1.000', '-1.0');
+       unit_test_func('format_decimal', '+1.000', '1.0');
        # important zeros after the decimal point
-       $errors += _test_format_misc('positive_decimal', '-1.020', '1.02');
-       $errors += _test_format_misc('positive_decimal', '+1.020', '1.02');
-       $errors += _test_format_misc('decimal', '-1.020', '-1.02');
-       $errors += _test_format_misc('decimal', '+1.020', '1.02');
-       $errors += _test_format_misc('positive_decimal', '-1.0020', '1.002');
-       $errors += _test_format_misc('positive_decimal', '+1.0020', '1.002');
-       $errors += _test_format_misc('decimal', '-1.0020', '-1.002');
-       $errors += _test_format_misc('decimal', '+1.0020', '1.002');
+       unit_test_func('format_positive_decimal', '-1.020', '1.02');
+       unit_test_func('format_positive_decimal', '+1.020', '1.02');
+       unit_test_func('format_decimal', '-1.020', '-1.02');
+       unit_test_func('format_decimal', '+1.020', '1.02');
+       unit_test_func('format_positive_decimal', '-1.0020', '1.002');
+       unit_test_func('format_positive_decimal', '+1.0020', '1.002');
+       unit_test_func('format_decimal', '-1.0020', '-1.002');
+       unit_test_func('format_decimal', '+1.0020', '1.002');
        # signs in weird places
-       $errors += _test_format_misc('positive_decimal', '-1.-0020', '1.002');
-       $errors += _test_format_misc('positive_decimal', '+1.-0020', '1.002');
-       $errors += _test_format_misc('decimal', '-1.-0020', '-1.002');
-       $errors += _test_format_misc('decimal', '+1.-0020', '1.002');
-       $errors += _test_format_misc('positive_decimal', '-1.0-020', '1.002');
-       $errors += _test_format_misc('positive_decimal', '+1.0-020', '1.002');
-       $errors += _test_format_misc('decimal', '-1.0-020', '-1.002');
-       $errors += _test_format_misc('decimal', '+1.0-020', '1.002');
-       $errors += _test_format_misc('positive_decimal', '-1-.0020', '1.002');
-       $errors += _test_format_misc('positive_decimal', '+1-.0020', '1.002');
-       $errors += _test_format_misc('decimal', '-1-.0020', '-1.002');
-       $errors += _test_format_misc('decimal', '+1-.0020', '1.002');
-       $errors += _test_format_misc('positive_decimal', '--1.0020', '1.002');
-       $errors += _test_format_misc('positive_decimal', '+-1.0020', '1.002');
-       $errors += _test_format_misc('decimal', '--1.0020', '-1.002');
-       $errors += _test_format_misc('decimal', '+-1.0020', '-1.002');
-
-
-       $errors += _test_format_misc('zip', '', '');
-       $errors += _test_format_misc('zip', '12345', '12345');
-       $errors += _test_format_misc('zip', 'snt3nvwm4vm2zvw0%^&3-', '34203');
-       $errors += _test_format_misc('zip', '123456', '12345-6');
-       $errors += _test_format_misc('zip', '1234567890', '12345-67890');
-
+       unit_test_func('format_positive_decimal', '-1.-0020', '1.002');
+       unit_test_func('format_positive_decimal', '+1.-0020', '1.002');
+       unit_test_func('format_decimal', '-1.-0020', '-1.002');
+       unit_test_func('format_decimal', '+1.-0020', '1.002');
+       unit_test_func('format_positive_decimal', '-1.0-020', '1.002');
+       unit_test_func('format_positive_decimal', '+1.0-020', '1.002');
+       unit_test_func('format_decimal', '-1.0-020', '-1.002');
+       unit_test_func('format_decimal', '+1.0-020', '1.002');
+       unit_test_func('format_positive_decimal', '-1-.0020', '1.002');
+       unit_test_func('format_positive_decimal', '+1-.0020', '1.002');
+       unit_test_func('format_decimal', '-1-.0020', '-1.002');
+       unit_test_func('format_decimal', '+1-.0020', '1.002');
+       unit_test_func('format_positive_decimal', '--1.0020', '1.002');
+       unit_test_func('format_positive_decimal', '+-1.0020', '1.002');
+       unit_test_func('format_decimal', '--1.0020', '-1.002');
+       unit_test_func('format_decimal', '+-1.0020', '-1.002');
+
+
+       unit_test_func('format_zip', '', '');
+       unit_test_func('format_zip', '12345', '12345');
+       unit_test_func('format_zip', 'snt3nvwm4vm2zvw0%^&3-', '34203');
+       unit_test_func('format_zip', '123456', '12345-6');
+       unit_test_func('format_zip', '1234567890', '12345-67890');
+
+       unit_test_func('format_filename', '1234567890', '1234567890');
+       unit_test_func('format_filename', 'A*b#C:D/E?f<g&H!I', 'a_b_c_d_e_f_g_h_i');
+       unit_test_func('format_filename', '-?', '__');
+       unit_test_func('format_filename', '--help', '_-help');
+       unit_test_func('format_filename', '.secret', '_secret');
+       # allow uppercase:
+       unit_test_func('format_filename', 'A*b#C:D/E?f<g&H!I', true, 'A_b_C_D_E_f_g_H_I');
 
        /* FIXME test these
-       format_filename($str, $allow_uppercase = false)
        format_path($str, $allow_uppercase = false)
        client_path_to_filename($path)
        format_image_w_h($str)