Commit d95d2201 by Edward Thomson Committed by Patrick Steinhardt

clar: accept a value for the summary filename

Accept an (optional) value for the summary filename.  Continues to
default to summary.xml.

(cherry picked from commit baa5c20d)
parent 5e8ac164
...@@ -139,6 +139,7 @@ static struct { ...@@ -139,6 +139,7 @@ static struct {
int exit_on_error; int exit_on_error;
int report_suite_names; int report_suite_names;
int write_summary; int write_summary;
const char *summary_file;
struct clar_explicit *explicit; struct clar_explicit *explicit;
struct clar_explicit *last_explicit; struct clar_explicit *last_explicit;
...@@ -183,6 +184,10 @@ static void clar_print_onabort(const char *msg, ...); ...@@ -183,6 +184,10 @@ static void clar_print_onabort(const char *msg, ...);
static void clar_unsandbox(void); static void clar_unsandbox(void);
static int clar_sandbox(void); static int clar_sandbox(void);
/* From summary.h */
static int clar_summary_init(const char *filename);
static void clar_summary_shutdown(void);
/* Load the declarations for the test suite */ /* Load the declarations for the test suite */
#include "clar.suite" #include "clar.suite"
...@@ -466,6 +471,8 @@ clar_parse_args(int argc, char **argv) ...@@ -466,6 +471,8 @@ clar_parse_args(int argc, char **argv)
case 'r': case 'r':
_clar.write_summary = 1; _clar.write_summary = 1;
_clar.summary_file = *(argument + 2) ? (argument + 2) :
"summary.xml";
break; break;
default: default:
...@@ -486,6 +493,11 @@ clar_test_init(int argc, char **argv) ...@@ -486,6 +493,11 @@ clar_test_init(int argc, char **argv)
if (argc > 1) if (argc > 1)
clar_parse_args(argc, argv); clar_parse_args(argc, argv);
if (_clar.write_summary && !clar_summary_init(_clar.summary_file)) {
clar_print_onabort("Failed to open the summary file: %s\n");
exit(-1);
}
if (clar_sandbox() < 0) { if (clar_sandbox() < 0) {
clar_print_onabort("Failed to sandbox the test runner.\n"); clar_print_onabort("Failed to sandbox the test runner.\n");
exit(-1); exit(-1);
...@@ -509,8 +521,6 @@ clar_test_run(void) ...@@ -509,8 +521,6 @@ clar_test_run(void)
return _clar.total_errors; return _clar.total_errors;
} }
static void clar_summary_write(void);
void void
clar_test_shutdown(void) clar_test_shutdown(void)
{ {
...@@ -526,7 +536,7 @@ clar_test_shutdown(void) ...@@ -526,7 +536,7 @@ clar_test_shutdown(void)
clar_unsandbox(); clar_unsandbox();
if (_clar.write_summary) if (_clar.write_summary)
clar_summary_write(); clar_summary_shutdown();
for (explicit = _clar.explicit; explicit; explicit = explicit_next) { for (explicit = _clar.explicit; explicit; explicit = explicit_next) {
explicit_next = explicit->next; explicit_next = explicit->next;
......
...@@ -2,6 +2,7 @@ ...@@ -2,6 +2,7 @@
#include <stdio.h> #include <stdio.h>
#include <time.h> #include <time.h>
static const char *filename;
static FILE *summary; static FILE *summary;
int clar_summary_close_tag(const char *tag, int indent) int clar_summary_close_tag(const char *tag, int indent)
...@@ -51,17 +52,19 @@ int clar_summary_failure(const char *type, const char *message, const char *desc ...@@ -51,17 +52,19 @@ int clar_summary_failure(const char *type, const char *message, const char *desc
return fprintf(summary, "\t\t\t<failure type=\"%s\"><![CDATA[%s\n%s]]></failure>\n", type, message, desc); return fprintf(summary, "\t\t\t<failure type=\"%s\"><![CDATA[%s\n%s]]></failure>\n", type, message, desc);
} }
void clar_summary_write(void) int clar_summary_init(const char *fn)
{
filename = fn;
summary = fopen(filename, "w");
return !!summary;
}
void clar_summary_shutdown(void)
{ {
struct clar_report *report; struct clar_report *report;
const char *last_suite = NULL; const char *last_suite = NULL;
char wd[1024];
summary = fopen("summary.xml", "w");
if (!summary) {
printf("failed to open summary.xml for writing\n");
return;
}
clar_summary_testsuites(); clar_summary_testsuites();
...@@ -94,5 +97,5 @@ void clar_summary_write(void) ...@@ -94,5 +97,5 @@ void clar_summary_write(void)
fclose(summary); fclose(summary);
printf("written summary file to %s\n", getcwd((char *)&wd, sizeof(wd))); printf("written summary file to %s\n", filename);
} }
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment