[PATCH] testsuite (committed): fix reporting for new gcc.test-framework tests
Janis Johnson
janis187@us.ibm.com
Tue Feb 1 17:38:00 GMT 2005
This patch reorganizes the awk script used in the new gcc.test-framework
tests to separate recording of pass/fail/ignore and to print a summary
like the one from test_summary. Checked in to mainline.
2005-02-01 Janis Johnson <janis187@us.ibm.com>
* gcc.test-framework/test-framework.awk: Change recording and
printing of passes and failures.
--- gcc.test-framework/test-framework.awk.orig 2005-01-31 14:06:11.351974648 -0800
+++ gcc.test-framework/test-framework.awk 2005-01-31 16:21:09.219997624 -0800
@@ -19,24 +19,43 @@
# Free Software Foundation, Inc., 59 Temple Place - Suite 330,
# Boston, MA 02111-1307, USA.
-BEGIN { skip = 1; pass = 0 }
+function pass(msg) {
+ passes++;
+ # printf("pass %s\n", $0);
+ }
+function fail(msg) {
+ fails++;
+ printf("fail %s\n", $0);
+ }
+function ignore(msg) {
+ # printf("ignore %s\n", $0);
+ }
+
+BEGIN { skip = 1; passes = 0; fails = 0; }
/Running.*test-frame/ { skip = 0; next }
/gcc Summary/ { skip = 1; next }
{ if (skip) next }
/^$/ { next }
# The post tests are always expected to pass.
-/^PASS.*-2.c/ { next }
+/^PASS.*-2.c/ { ignore(); next }
# dg-xfail-if applies to the compile step; these should be XPASS for the
# compile step on dox tests, which are run tests.
-/^XPASS.*dox.*xiff.*-1.c.*(test for excess errors)/ { next }
+/^XPASS.*dox.*xiff.*-1.c.*(test for excess errors)/ { ignore(); next }
# xfail for scan-assembler-not tests doesn't apply to the compile step.
-/^PASS.*sa.*-1.c.*(test for excess errors)/ { next }
+/^PASS.*sa.*-1.c.*(test for excess errors)/ { ignore(); next }
# The other dox tests pass the compile step; ignore that message.
-/^PASS.*dox.*(test for excess errors)/ { next }
-/^PASS/ { if (match ($0, "exp-P")) { pass++; next } }
-/^FAIL/ { if (match ($0, "exp-F")) { pass++; next } }
-/^XPASS/ { if (match ($0, "exp-XP")) { pass++; next } }
-/^XFAIL/ { if (match ($0, "exp-XF")) { pass++; next } }
-/^UNSUPPORTED/ { if (match ($0, "exp-U")) { pass++; next } }
- { print }
-END { printf("%d tests passed\n", pass) }
+/^PASS.*dox.*(test for excess errors)/ { ignore(); next }
+# Ignore lines that begin with comma.
+/^,/ { ignore(); next }
+/^PASS/ { if (match ($0, "exp-P")) { pass(); next } }
+/^FAIL/ { if (match ($0, "exp-F")) { pass(); next } }
+/^XPASS/ { if (match ($0, "exp-XP")) { pass(); next } }
+/^XFAIL/ { if (match ($0, "exp-XF")) { pass(); next } }
+/^UNSUPPORTED/ { if (match ($0, "exp-U")) { pass(); next } }
+ { fail() }
+END {
+ printf("\n\t\t=== Test Framework Summary ===\n\n");
+ printf("# of expected passes\t\t%d\n", passes);
+ if (fails != 0)
+ printf("# of unexpected failures\t%d\n", fails);
+ }
More information about the Gcc-patches
mailing list