]> gitweb.michael.orlitzky.com - octave.git/blobdiff - run-tests.m
Take an optional integer parameter to ./run-tests.m to loop more than once.
[octave.git] / run-tests.m
index ef72b10731fecb8f6f324d4b25150153140af948..001e7409d00004d7cdc85a2e676cb29c9aa8e2f8 100755 (executable)
@@ -1,15 +1,32 @@
 #!/usr/bin/octave --silent
+#
+# You'll need to use the .octaverc in this directory to get the proper
+# paths. You can pass it an integer on the command-line to specify how
+# many times we should run the test suite in succession. The default
+# is 1.
+#
+
+addpath('./unit_test');
+
+global unittest_results;
 
 unit_init(1, {});
 
-unit_test_equals("sin[0] == 0", ...
-                0, ...
-                divided_difference(@sin, 0));
+test_files = glob('tests/*.m');
+
+loop_count = 1;
+arg_list = argv();
+if (length(arg_list) > 0)
+  loop_count = arg_list{1};
+end
+
+## Source every file that matches the glob above.
+for idx = [ 1 : loop_count ]
+  cellfun(@source, test_files);
+end
 
-unit_test_equals("sin[0, pi] == 0", ...
-                0, ...
-                divided_difference(@sin, [0,pi]));
 
-unit_test_equals("sin[0, pi, 2*pi] == 0", ...
-                0, ...
-                divided_difference(@sin, [0,pi,2*pi]));
+fprintf('\n');
+fprintf('Total tests attempted: %d\n', unittest_results.total);
+fprintf('Total tests passed: %d\n', unittest_results.pass);
+fprintf('Total tests failed: %d\n', unittest_results.fail);