[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