summaryrefslogtreecommitdiff
path: root/lib/torture/torture.c
diff options
context:
space:
mode:
authorJelmer Vernooij <jelmer@samba.org>2010-03-31 02:57:47 +0200
committerJelmer Vernooij <jelmer@samba.org>2010-03-31 02:57:47 +0200
commit31094b0e8ca73e3150de9de689f4c5c38b2e9f1f (patch)
tree5095475c46abfc5bd0ccb8c147c9e6279ba96b84 /lib/torture/torture.c
parent197c98292bd838e27da6692ba8e7984f12a66fef (diff)
downloadsamba-31094b0e8ca73e3150de9de689f4c5c38b2e9f1f.tar.gz
samba-31094b0e8ca73e3150de9de689f4c5c38b2e9f1f.tar.bz2
samba-31094b0e8ca73e3150de9de689f4c5c38b2e9f1f.zip
smbtorture: Report number of available tests in a testsuite using subunit.
Diffstat (limited to 'lib/torture/torture.c')
-rw-r--r--lib/torture/torture.c21
1 files changed, 21 insertions, 0 deletions
diff --git a/lib/torture/torture.c b/lib/torture/torture.c
index 672726ebf2..9adf6816b8 100644
--- a/lib/torture/torture.c
+++ b/lib/torture/torture.c
@@ -245,6 +245,23 @@ struct torture_tcase *torture_suite_add_tcase(struct torture_suite *suite,
return tcase;
}
+int torture_suite_children_count(const struct torture_suite *suite)
+{
+ int ret = 0;
+ struct torture_tcase *tcase;
+ struct torture_test *test;
+ struct torture_suite *tsuite;
+ for (tcase = suite->testcases; tcase; tcase = tcase->next) {
+ for (test = tcase->tests; test; test = test->next) {
+ ret++;
+ }
+ }
+ for (tsuite = suite->children; tsuite; tsuite = tsuite->next) {
+ ret ++;
+ }
+ return ret;
+}
+
/**
* Run a torture test suite.
*/
@@ -259,6 +276,8 @@ bool torture_run_suite(struct torture_context *context,
if (context->results->ui_ops->suite_start)
context->results->ui_ops->suite_start(context, suite);
+ context->results->ui_ops->progress(context,
+ torture_suite_children_count(suite), TORTURE_PROGRESS_SET);
old_testname = context->active_testname;
if (old_testname != NULL)
context->active_testname = talloc_asprintf(context, "%s-%s",
@@ -271,7 +290,9 @@ bool torture_run_suite(struct torture_context *context,
}
for (tsuite = suite->children; tsuite; tsuite = tsuite->next) {
+ context->results->ui_ops->progress(context, 0, TORTURE_PROGRESS_PUSH);
ret &= torture_run_suite(context, tsuite);
+ context->results->ui_ops->progress(context, 0, TORTURE_PROGRESS_POP);
}
talloc_free(context->active_testname);