test/harness/testcaseio.c
author ali <ali@juiblex.co.uk>
Wed Oct 02 23:42:45 2013 +0100 (2013-10-02)
changeset 145 a67870b6958e
parent 17 2c88fd553e5d
child 191 189183b37598
child 200 8e0ba1a088c4
permissions -rw-r--r--
Update documentation for 2.0.61
ali@0
     1
#include <stdlib.h>
ali@0
     2
#include <stdio.h>
ali@0
     3
#include <string.h>
ali@6
     4
#include <glib.h>
ali@5
     5
#include <bl/bl.h>
ali@0
     6
#include "testcaseparser.h"
ali@9
     7
#include "testcaseinput.h"
ali@136
     8
#include "testcaseoutput.h"
ali@0
     9
#include "testcaseio.h"
ali@17
    10
#include "warningsparser.h"
ali@0
    11
ali@0
    12
/*
ali@0
    13
 * Read a testcase in from a file.
ali@11
    14
 * On error, print a suitable message using g_printerr and return NULL.
ali@0
    15
 * The returned testcase should be freed with testcase_free().
ali@0
    16
 */
ali@0
    17
Testcase *testcase_parse_file(const char *filename)
ali@0
    18
{
ali@0
    19
    Testcase *testcase;
ali@0
    20
    TestcaseParser *parser;
ali@9
    21
    TestcaseInput *input=NULL;
ali@17
    22
    GMarkupParseContext *context;
ali@17
    23
    GError *err=NULL;
ali@9
    24
    char *s,*arg;
ali@0
    25
    const char *tag,*text;
ali@6
    26
    gboolean found_tag=FALSE;
ali@0
    27
    parser=testcase_parser_new_from_file(filename);
ali@0
    28
    if (!parser)
ali@0
    29
	return NULL;
ali@0
    30
    if (!*testcase_parser_get_flag(parser))
ali@0
    31
    {
ali@11
    32
	g_printerr("%s: Not a valid testcase (flag)\n",filename);
ali@0
    33
	testcase_parser_free(parser);
ali@0
    34
	return NULL;
ali@0
    35
    }
ali@6
    36
    testcase=g_new0(Testcase,1);
ali@6
    37
    testcase->basename=g_path_get_basename(filename);
ali@0
    38
    s=strrchr(testcase->basename,'.');
ali@0
    39
    if (s)
ali@0
    40
	*s='\0';
ali@0
    41
    while(testcase_parser_get_next_tag(parser,&tag,&text))
ali@0
    42
    {
ali@9
    43
	if (!input && !strcmp(tag,"INPUT"))
ali@9
    44
	    input=testcase_input_new("TEST-XXXXXX",text);
ali@9
    45
	else if (g_str_has_prefix(tag,"INPUT(") && tag[strlen(tag)-1]==')')
ali@9
    46
	{
ali@9
    47
	    arg=g_strndup(tag+6,strlen(tag)-7);
ali@9
    48
	    s=g_path_get_dirname(arg);
ali@9
    49
	    if (strcmp(s,"."))
ali@9
    50
	    {
ali@9
    51
		/*
ali@9
    52
		 * Otherwise it would be possible to overwrite an arbitary
ali@9
    53
		 * file on somebody's computer by getting them to run a
ali@9
    54
		 * testcase!
ali@9
    55
		 */
ali@11
    56
		g_printerr(
ali@9
    57
		  "%s: Input files may not have a directory component\n",arg);
ali@9
    58
		g_free(s);
ali@9
    59
		g_free(arg);
ali@9
    60
		testcase_free(testcase);
ali@9
    61
		testcase_parser_free(parser);
ali@9
    62
		return NULL;
ali@9
    63
	    }
ali@9
    64
	    g_free(s);
ali@9
    65
	    testcase->inputs=g_slist_prepend(testcase->inputs,
ali@9
    66
	      testcase_input_new(arg,text));
ali@9
    67
	    if (!strstr(arg,"XXXXXX"))
ali@9
    68
		testcase->flags|=TESTCASE_TMP_DIR;
ali@9
    69
	    g_free(arg);
ali@9
    70
	}
ali@17
    71
	else if (!testcase->expected && !testcase->warnings &&
ali@17
    72
	  !strcmp(tag,"EXPECTED"))
ali@6
    73
	    testcase->expected=g_strdup(text);
ali@136
    74
	else if (g_str_has_prefix(tag,"EXPECTED(") && tag[strlen(tag)-1]==')')
ali@136
    75
	{
ali@136
    76
	    arg=g_strndup(tag+9,strlen(tag)-10);
ali@136
    77
	    s=g_path_get_dirname(arg);
ali@136
    78
	    if (strcmp(s,"."))
ali@136
    79
	    {
ali@136
    80
		g_printerr("%s: Expected files may not have a "
ali@136
    81
		  "directory component\n",arg);
ali@136
    82
		g_free(s);
ali@136
    83
		g_free(arg);
ali@136
    84
		testcase_free(testcase);
ali@136
    85
		testcase_parser_free(parser);
ali@136
    86
		return NULL;
ali@136
    87
	    }
ali@136
    88
	    g_free(s);
ali@136
    89
	    testcase->outputs=g_slist_prepend(testcase->outputs,
ali@136
    90
	      testcase_output_new(arg,text));
ali@136
    91
	    g_free(arg);
ali@136
    92
	}
ali@17
    93
	else if (!testcase->expected && !testcase->warnings &&
ali@17
    94
	  !strcmp(tag,"WARNINGS"))
ali@17
    95
	{
ali@17
    96
	    context=warnings_parse_context_new(testcase);
ali@17
    97
	    if (!g_markup_parse_context_parse(context,text,-1,&err) ||
ali@17
    98
	      !g_markup_parse_context_end_parse(context,&err))
ali@17
    99
	    {
ali@17
   100
		g_markup_parse_context_free(context);
ali@17
   101
		g_printerr("%s\n",err->message);
ali@17
   102
		g_clear_error(&err);
ali@17
   103
		testcase_free(testcase);
ali@17
   104
		testcase_parser_free(parser);
ali@17
   105
		return NULL;
ali@17
   106
	    }
ali@17
   107
	    g_markup_parse_context_free(context);
ali@17
   108
	}
ali@7
   109
	else if (!testcase->encoding && !strcmp(tag,"ENCODING"))
ali@8
   110
	    testcase->encoding=g_strchomp(g_strdup(text));
ali@136
   111
	else if (!testcase->options && !strcmp(tag,"OPTIONS"))
ali@9
   112
	{
ali@9
   113
	    testcase->options=g_strsplit(text,"\n",0);
ali@136
   114
	    if (testcase->options && g_strv_length(testcase->options)>0)
ali@136
   115
	    {
ali@136
   116
		g_free(testcase->options[g_strv_length(testcase->options)-1]);
ali@136
   117
		testcase->options[g_strv_length(testcase->options)-1]=NULL;
ali@136
   118
	    }
ali@9
   119
	}
ali@0
   120
	else
ali@0
   121
	{
ali@11
   122
	    g_printerr("%s: Not a valid testcase (%s)\n",filename,tag);
ali@0
   123
	    testcase_free(testcase);
ali@0
   124
	    testcase_parser_free(parser);
ali@0
   125
	    return NULL;
ali@0
   126
	}
ali@0
   127
	found_tag=TRUE;
ali@0
   128
    }
ali@0
   129
    if (!testcase_parser_at_eof(parser))
ali@0
   130
    {
ali@0
   131
	if (found_tag)
ali@11
   132
	    g_printerr("%s: Not a valid testcase (garbage at end)\n",
ali@0
   133
	      filename);
ali@0
   134
	else
ali@11
   135
	    g_printerr("%s: Not a valid testcase (no valid tags)\n",
ali@0
   136
	      filename);
ali@0
   137
	testcase_free(testcase);
ali@0
   138
	testcase_parser_free(parser);
ali@0
   139
	return NULL;
ali@0
   140
    }
ali@9
   141
    if (!input)
ali@9
   142
	input=testcase_input_new("TEST-XXXXXX",NULL);
ali@9
   143
    testcase->inputs=g_slist_prepend(testcase->inputs,input);
ali@0
   144
    testcase_parser_free(parser);
ali@0
   145
    return testcase;
ali@0
   146
}