diff options
author | Magnus Hagander <magnus@hagander.net> | 2007-06-12 11:07:34 +0000 |
---|---|---|
committer | Magnus Hagander <magnus@hagander.net> | 2007-06-12 11:07:34 +0000 |
commit | 09922597c5f460ab02882716c371b2a5c47e742e (patch) | |
tree | 50c02e13bf202463570cf107fbcda70b42812bcc /src/test/regress/pg_regress_main.c | |
parent | e514740e699d306b744849e43bcd2ef9728d464b (diff) | |
download | postgresql-09922597c5f460ab02882716c371b2a5c47e742e.tar.gz |
Rewrite ECPG regression test driver in C, by splitting the standard
regression driver into two parts and reusing half of it. Required to
run ECPG tests without a shell on MSVC builds.
Fix ECPG thread tests for MSVC build (incl output files).
Joachim Wieland and Magnus Hagander
Diffstat (limited to 'src/test/regress/pg_regress_main.c')
-rw-r--r-- | src/test/regress/pg_regress_main.c | 78 |
1 files changed, 78 insertions, 0 deletions
diff --git a/src/test/regress/pg_regress_main.c b/src/test/regress/pg_regress_main.c new file mode 100644 index 0000000000..fea5c35f59 --- /dev/null +++ b/src/test/regress/pg_regress_main.c @@ -0,0 +1,78 @@ +/*------------------------------------------------------------------------- + * + * pg_regress_main --- regression test for the main backend + * + * This is a C implementation of the previous shell script for running + * the regression tests, and should be mostly compatible with it. + * Initial author of C translation: Magnus Hagander + * + * This code is released under the terms of the PostgreSQL License. + * + * Portions Copyright (c) 1996-2007, PostgreSQL Global Development Group + * Portions Copyright (c) 1994, Regents of the University of California + * + * $PostgreSQL: pgsql/src/test/regress/pg_regress_main.c,v 1.1 2007/06/12 11:07:34 mha Exp $ + * + *------------------------------------------------------------------------- + */ + +#include "pg_regress.h" + +/* + * start a psql test process for specified file (including redirection), + * and return process ID + */ +static PID_TYPE +psql_start_test(const char *testname, + _stringlist **resultfiles, + _stringlist **expectfiles, + _stringlist **tags) +{ + PID_TYPE pid; + char infile[MAXPGPATH]; + char outfile[MAXPGPATH]; + char expectfile[MAXPGPATH]; + char psql_cmd[MAXPGPATH * 3]; + + snprintf(infile, sizeof(infile), "%s/sql/%s.sql", + inputdir, testname); + snprintf(outfile, sizeof(outfile), "%s/results/%s.out", + outputdir, testname); + snprintf(expectfile, sizeof(expectfile), "%s/expected/%s.out", + inputdir, testname); + + add_stringlist_item(resultfiles, outfile); + add_stringlist_item(expectfiles, expectfile); + + snprintf(psql_cmd, sizeof(psql_cmd), + SYSTEMQUOTE "\"%s%spsql\" -X -a -q -d \"%s\" < \"%s\" > \"%s\" 2>&1" SYSTEMQUOTE, + psqldir ? psqldir : "", + psqldir ? "/" : "", + dblist->str, + infile, + outfile); + + pid = spawn_process(psql_cmd); + + if (pid == INVALID_PID) + { + fprintf(stderr, _("could not start process for test %s\n"), + testname); + exit_nicely(2); + } + + return pid; +} + +static void +psql_init(void) +{ + /* set default regression database name */ + add_stringlist_item(&dblist, "regression"); +} + +int +main(int argc, char *argv[]) +{ + return regression_main(argc, argv, psql_init, psql_start_test); +} |