- Add a parameter for listing all valid test names

- Generate valid XHTML 1.0 Strict

svn path=/trunk/; revision=33820
This commit is contained in:
Colin Finck 2008-06-01 18:37:55 +00:00
parent 879d178c13
commit 0f76b280cc

View file

@ -1,17 +1,30 @@
#include "apitest.h" #include "apitest.h"
const char szFileHeader[] = "<html><head><style>\ntd.red {color:red}\ntd.green{color:green}\n</style>\n</head>\n<body>\n<head>\n"; const char szFileHeader1[] = "<!DOCTYPE html PUBLIC \"-//W3C//DTD XHTML 1.0 Strict//EN\" \"http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd\">\n"
const char szTableHeader[] = "<table width = '800'><tr><th align='left'>Function</th><th align='left'>Status</th><th align='left'>Tests (all/passed/failed)</th><th align='left'>Regressions</th></tr>"; "<html xmlns=\"http://www.w3.org/1999/xhtml\">\n"
"<head>\n"
"<meta http-equiv=\"content-type\" content=\"text/html; charset=utf-8\" />\n";
const char szFileHeader2[] = "<style type=\"text/css\">\n"
"body {font-family: sans-serif;}\n"
"table {width: 100%;}\n"
"th {text-align: left;}\n"
"td.red {color: red;}\n"
"td.green {color: green;}\n"
"</style>\n"
"</head>\n"
"<body>\n";
const char szTableHeader[] = "<table><tr><th>Function</th><th>Status</th><th>Tests (all/passed/failed)</th><th>Regressions</th></tr>";
const char szFileFooter[] = "</table></body></html>"; const char szFileFooter[] = "</table></body></html>";
void void
OutputUsage(LPWSTR pszName) OutputUsage(LPWSTR pszName)
{ {
printf("\nUsage:\n\n"); printf("\nUsage:\n\n");
printf("%ls.exe <TestName> - perform individual test\n", pszName); printf("%ls.exe <TestName> - Perform individual test\n", pszName);
printf("%ls.exe all - perform all tests\n", pszName); printf("%ls.exe all - Perform all tests\n", pszName);
printf("%ls.exe status - create api status file\n", pszName); printf("%ls.exe tests - List the valid test names\n", pszName);
printf("%ls.exe -r ... - perform regression testing\n", pszName); printf("%ls.exe status - Create api status file\n", pszName);
printf("%ls.exe -r ... - Perform regression testing\n", pszName);
printf("\n"); printf("\n");
} }
@ -20,10 +33,16 @@ WriteFileHeader(UINT hFile, LPWSTR pszModule)
{ {
char szHeader[100]; char szHeader[100];
_write(hFile, szFileHeader, strlen(szFileHeader)); _write(hFile, szFileHeader1, strlen(szFileHeader1));
sprintf(szHeader, "<H1>Test results for %ls</H1>", pszModule); sprintf(szHeader, "<title>%ls Test results</title>", pszModule);
_write(hFile, szHeader, strlen(szHeader)); _write(hFile, szHeader, strlen(szHeader));
_write(hFile, szFileHeader2, strlen(szFileHeader2));
sprintf(szHeader, "<h1>Test results for %ls</h1>", pszModule);
_write(hFile, szHeader, strlen(szHeader));
_write(hFile, szTableHeader, strlen(szTableHeader)); _write(hFile, szTableHeader, strlen(szTableHeader));
return TRUE; return TRUE;
} }
@ -37,19 +56,19 @@ WriteRow(UINT hFile, LPWSTR pszFunction, PTESTINFO pti)
switch(pti->nApiStatus) switch(pti->nApiStatus)
{ {
case APISTATUS_NOT_FOUND: case APISTATUS_NOT_FOUND:
strcat(szLine, "<td class='red'>not found</td>"); strcat(szLine, "<td class=\"red\">not found</td>");
break; break;
case APISTATUS_UNIMPLEMENTED: case APISTATUS_UNIMPLEMENTED:
strcat(szLine, "<td class='red'>unimplemented</td>"); strcat(szLine, "<td class=\"red\">unimplemented</td>");
break; break;
case APISTATUS_ASSERTION_FAILED: case APISTATUS_ASSERTION_FAILED:
strcat(szLine, "<td class='red'>assertion failed</td>"); strcat(szLine, "<td class=\"red\">assertion failed</td>");
break; break;
case APISTATUS_REGRESSION: case APISTATUS_REGRESSION:
strcat(szLine, "<td class='red'>Regression!</td>"); strcat(szLine, "<td class=\"red\">Regression!</td>");
break; break;
case APISTATUS_NORMAL: case APISTATUS_NORMAL:
strcat(szLine, "<td class='green'>Implemented</td>"); strcat(szLine, "<td class=\"green\">Implemented</td>");
break; break;
} }
@ -99,6 +118,16 @@ TestMain(LPWSTR pszName, LPWSTR pszModule)
bAll = TRUE; bAll = TRUE;
bStatus = TRUE; bStatus = TRUE;
} }
else if (_wcsicmp(argv[i], L"tests") == 0)
{
/* List all the tests and exit */
printf("Valid test names:\n\n");
for (i = 0; i < NumTests(); i++)
printf("%ls\n", TestList[i].Test);
return 0;
}
} }
if (bStatus) if (bStatus)