@ -1,12 +1,10 @@
from ephemeral_port_reserve import reserve # type: ignore
from ephemeral_port_reserve import reserve # type: ignore
from glob import glob
import itertools
import itertools
import logging
import logging
import os
import os
import psycopg2 # type: ignore
import psycopg2 # type: ignore
import random
import random
import re
import shutil
import shutil
import signal
import signal
import sqlite3
import sqlite3
@ -117,28 +115,23 @@ class PostgresDbProvider(object):
print ( " Starting PostgresDbProvider " )
print ( " Starting PostgresDbProvider " )
def locate_path ( self ) :
def locate_path ( self ) :
prefix = ' /usr/lib/postgresql/* '
# Use `pg_config` to determine correct PostgreSQL installation
matches = glob ( prefix )
pg_config = shutil . which ( ' pg_config ' )
if not pg_config :
candidates = { }
raise ValueError ( " Could not find `pg_config` to determine PostgreSQL binaries. Is PostgreSQL installed? " )
for m in matches :
g = re . search ( r ' ([0-9]+[ \ .0-9]*) ' , m )
bindir = subprocess . check_output ( [ pg_config , ' --bindir ' ] ) . decode ( ) . rstrip ( )
if not g :
if not os . path . isdir ( bindir ) :
continue
raise ValueError ( " Error: `pg_config --bindir` didn ' t return a proper path: {} " . format ( bindir ) )
candidates [ float ( g . group ( 1 ) ) ] = m
initdb = os . path . join ( bindir , ' initdb ' )
if len ( candidates ) == 0 :
postgres = os . path . join ( bindir , ' postgres ' )
raise ValueError ( " Could not find `postgres` and `initdb` binaries in {} . Is postgresql installed? " . format ( prefix ) )
if os . path . isfile ( initdb ) and os . path . isfile ( postgres ) :
if os . access ( initdb , os . X_OK ) and os . access ( postgres , os . X_OK ) :
# Now iterate in reverse order through matches
logging . info ( " Found `postgres` and `initdb` in {} " . format ( bindir ) )
for k , v in sorted ( candidates . items ( ) ) [ : : - 1 ] :
initdb = os . path . join ( v , ' bin ' , ' initdb ' )
postgres = os . path . join ( v , ' bin ' , ' postgres ' )
if os . path . isfile ( initdb ) and os . path . isfile ( postgres ) :
logging . info ( " Found `postgres` and `initdb` in {} " . format ( os . path . join ( v , ' bin ' ) ) )
return initdb , postgres
return initdb , postgres
raise ValueError ( " Could not find `postgres` and `initdb` in any of the possible paths: {} " . format ( candidates . values ( ) ) )
raise ValueError ( " Could not find `postgres` and `initdb` binaries in {} " . format ( bindir ) )
def start ( self ) :
def start ( self ) :
passfile = os . path . join ( self . directory , " pgpass.txt " )
passfile = os . path . join ( self . directory , " pgpass.txt " )