Browse Source

chore: optimize postgres binary lookup

This will change the current hardwired PostgreSQL binary lookup mechanism to
utilizing the `pg_config --bindir` utility that should work better for most
distributions. The old method caused issues at least on Archlinux.

Changelog-None
travis-experimental
Michael Schmoock 4 years ago
committed by Rusty Russell
parent
commit
6907e85a39
  1. 37
      contrib/pyln-testing/pyln/testing/db.py

37
contrib/pyln-testing/pyln/testing/db.py

@ -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")

Loading…
Cancel
Save