PostgreSQL Source Code  git master
 All Data Structures Namespaces Files Functions Variables Typedefs Enumerations Enumerator Macros
isolation_main.c File Reference
#include "pg_regress.h"
Include dependency graph for isolation_main.c:

Go to the source code of this file.

Macros

#define PG_ISOLATION_VERSIONSTR   "isolationtester (PostgreSQL) " PG_VERSION "\n"
 

Functions

static PID_TYPE isolation_start_test (const char *testname, _stringlist **resultfiles, _stringlist **expectfiles, _stringlist **tags)
 
static void isolation_init (int argc, char **argv)
 
int main (int argc, char *argv[])
 

Variables

char saved_argv0 [MAXPGPATH]
 
char isolation_exec [MAXPGPATH]
 
bool looked_up_isolation_exec = false
 

Macro Definition Documentation

#define PG_ISOLATION_VERSIONSTR   "isolationtester (PostgreSQL) " PG_VERSION "\n"

Definition at line 19 of file isolation_main.c.

Referenced by isolation_start_test().

Function Documentation

static void isolation_init ( int  argc,
char **  argv 
)
static

Definition at line 99 of file isolation_main.c.

References _, add_stringlist_item(), dblist, MAXPGPATH, saved_argv0, and strlcpy().

Referenced by main().

100 {
101  size_t argv0_len;
102 
103  /*
104  * We unfortunately cannot do the find_other_exec() lookup to find the
105  * "isolationtester" binary here. regression_main() calls the
106  * initialization functions before parsing the commandline arguments and
107  * thus hasn't changed the library search path at this point which in turn
108  * can cause the "isolationtester -V" invocation that find_other_exec()
109  * does to fail since it's linked to libpq. So we instead copy argv[0]
110  * and do the lookup the first time through isolation_start_test().
111  */
112  argv0_len = strlcpy(saved_argv0, argv[0], MAXPGPATH);
113  if (argv0_len >= MAXPGPATH)
114  {
115  fprintf(stderr, _("path for isolationtester executable is longer than %d bytes\n"),
116  (int) (MAXPGPATH - 1));
117  exit(2);
118  }
119 
120  /* set default regression database name */
121  add_stringlist_item(&dblist, "isolation_regression");
122 }
static void static void static void void add_stringlist_item(_stringlist **listhead, const char *str)
Definition: pg_regress.c:152
#define MAXPGPATH
_stringlist * dblist
Definition: pg_regress.c:70
size_t strlcpy(char *dst, const char *src, size_t siz)
Definition: strlcpy.c:45
char saved_argv0[MAXPGPATH]
#define _(x)
Definition: elog.c:84
static PID_TYPE isolation_start_test ( const char *  testname,
_stringlist **  resultfiles,
_stringlist **  expectfiles,
_stringlist **  tags 
)
static

Definition at line 26 of file isolation_main.c.

References _, add_stringlist_item(), dblist, file_exists(), find_other_exec(), infile(), inputdir, INVALID_PID, isolation_exec, launcher, looked_up_isolation_exec, MAXPGPATH, outfile, outputdir, PG_ISOLATION_VERSIONSTR, PID_TYPE, saved_argv0, snprintf(), spawn_process(), and _stringlist::str.

Referenced by main().

30 {
31  PID_TYPE pid;
32  char infile[MAXPGPATH];
33  char outfile[MAXPGPATH];
34  char expectfile[MAXPGPATH];
35  char psql_cmd[MAXPGPATH * 3];
36  size_t offset = 0;
37 
38  /* need to do the path lookup here, check isolation_init() for details */
40  {
41  /* look for isolationtester binary */
42  if (find_other_exec(saved_argv0, "isolationtester",
44  {
45  fprintf(stderr, _("could not find proper isolationtester binary\n"));
46  exit(2);
47  }
49  }
50 
51  /*
52  * Look for files in the output dir first, consistent with a vpath search.
53  * This is mainly to create more reasonable error messages if the file is
54  * not found. It also allows local test overrides when running pg_regress
55  * outside of the source tree.
56  */
57  snprintf(infile, sizeof(infile), "%s/specs/%s.spec",
58  outputdir, testname);
59  if (!file_exists(infile))
60  snprintf(infile, sizeof(infile), "%s/specs/%s.spec",
61  inputdir, testname);
62 
63  snprintf(outfile, sizeof(outfile), "%s/results/%s.out",
64  outputdir, testname);
65 
66  snprintf(expectfile, sizeof(expectfile), "%s/expected/%s.out",
67  outputdir, testname);
68  if (!file_exists(expectfile))
69  snprintf(expectfile, sizeof(expectfile), "%s/expected/%s.out",
70  inputdir, testname);
71 
72  add_stringlist_item(resultfiles, outfile);
73  add_stringlist_item(expectfiles, expectfile);
74 
75  if (launcher)
76  offset += snprintf(psql_cmd + offset, sizeof(psql_cmd) - offset,
77  "%s ", launcher);
78 
79  snprintf(psql_cmd + offset, sizeof(psql_cmd) - offset,
80  "\"%s\" \"dbname=%s\" < \"%s\" > \"%s\" 2>&1",
82  dblist->str,
83  infile,
84  outfile);
85 
86  pid = spawn_process(psql_cmd);
87 
88  if (pid == INVALID_PID)
89  {
90  fprintf(stderr, _("could not start process for test %s\n"),
91  testname);
92  exit(2);
93  }
94 
95  return pid;
96 }
char isolation_exec[MAXPGPATH]
int find_other_exec(const char *argv0, const char *target, const char *versionstr, char *retpath)
Definition: exec.c:307
char * str
Definition: pg_regress.h:25
static void static void static void void add_stringlist_item(_stringlist **listhead, const char *str)
Definition: pg_regress.c:152
#define PID_TYPE
Definition: pg_regress.h:15
int snprintf(char *str, size_t count, const char *fmt,...) pg_attribute_printf(3
char * launcher
Definition: pg_regress.c:75
PID_TYPE spawn_process(const char *cmdline)
Definition: pg_regress.c:1124
static bool file_exists(const char *name)
Definition: dfmgr.c:450
#define MAXPGPATH
_stringlist * dblist
Definition: pg_regress.c:70
#define INVALID_PID
Definition: pg_regress.h:16
bool looked_up_isolation_exec
char * outputdir
Definition: pg_regress.c:73
char * inputdir
Definition: pg_regress.c:72
static void infile(const char *filename)
Definition: zic.c:1151
char saved_argv0[MAXPGPATH]
#define PG_ISOLATION_VERSIONSTR
static char * outfile
#define _(x)
Definition: elog.c:84
int main ( int  argc,
char *  argv[] 
)

Definition at line 125 of file isolation_main.c.

References isolation_init(), isolation_start_test(), and regression_main().

126 {
128 }
static void isolation_init(int argc, char **argv)
static PID_TYPE isolation_start_test(const char *testname, _stringlist **resultfiles, _stringlist **expectfiles, _stringlist **tags)
int regression_main(int argc, char *argv[], init_function ifunc, test_function tfunc)
Definition: pg_regress.c:2018

Variable Documentation

char isolation_exec[MAXPGPATH]

Definition at line 16 of file isolation_main.c.

Referenced by isolation_start_test().

bool looked_up_isolation_exec = false

Definition at line 17 of file isolation_main.c.

Referenced by isolation_start_test().

char saved_argv0[MAXPGPATH]

Definition at line 15 of file isolation_main.c.

Referenced by isolation_init(), and isolation_start_test().