Opened 2 years ago

Closed 2 years ago

#63831 closed defect (fixed)

postgresql13 depends on kerberos5 without declaring a dependency on it

Reported by: RobK88 Owned by: jyrkiwahlstedt
Priority: Normal Milestone:
Component: ports Version: 2.7.1
Keywords: Cc:
Port: postgresql13

Description

I am unable to upgrade postgresql13 on Lion. Fails the configuration stage.

bash-3.2$ /usr/bin/sudo port -v upgrade  postgresql13
--->  Computing dependencies for postgresql13.
--->  Fetching distfiles for postgresql13
--->  Verifying checksums for postgresql13
--->  Checksumming postgresql-13.4.tar.bz2
--->  Extracting postgresql13
--->  Extracting postgresql-13.4.tar.bz2
Executing:  cd "/opt/local/var/macports/build/_opt_local_var_macports_sources_rsync.macports.org_release_tarballs_ports_databases_postgresql13/postgresql13/work" && /usr/bin/bzip2 -dc '/opt/local/var/macports/distfiles/postgresql13/postgresql-13.4.tar.bz2' | /usr/bin/gnutar --no-same-owner -xf - 
--->  Applying patches to postgresql13
--->  Applying patch-no_doc.diff
Executing:  cd "/opt/local/var/macports/build/_opt_local_var_macports_sources_rsync.macports.org_release_tarballs_ports_databases_postgresql13/postgresql13/work/postgresql-13.4" && /usr/bin/patch -p0 < '/opt/local/var/macports/sources/rsync.macports.org/release/tarballs/ports/databases/postgresql13/files/patch-no_doc.diff'
patching file GNUmakefile.in
--->  Configuring postgresql13
Executing:  cd "/opt/local/var/macports/build/_opt_local_var_macports_sources_rsync.macports.org_release_tarballs_ports_databases_postgresql13/postgresql13/work/postgresql-13.4" && ./configure --prefix=/opt/local PG_SYSROOT=disabled --sysconfdir=/opt/local/etc/postgresql13 --bindir=/opt/local/lib/postgresql13/bin --libdir=/opt/local/lib/postgresql13 --includedir=/opt/local/include/postgresql13 --datadir=/opt/local/share/postgresql13 --docdir=/opt/local/share/doc/postgresql13 --mandir=/opt/local/share/man --with-includes=/opt/local/include --with-libraries=/opt/local/lib --with-openssl --with-bonjour --with-readline --with-zlib --with-libxml --with-libxslt --with-gssapi --enable-thread-safety --with-uuid=e2fs --with-icu 
checking build system type... x86_64-apple-darwin11.4.2
checking host system type... x86_64-apple-darwin11.4.2
checking which template to use... darwin
checking whether NLS is wanted... no
checking for default port number... 5432
checking for block size... 8kB
checking for segment size... 1GB
checking for WAL block size... 8kB
checking whether the C compiler works... yes
checking for C compiler default output file name... a.out
checking for suffix of executables... 
checking whether we are cross compiling... no
checking for suffix of object files... o
checking whether we are using the GNU C compiler... yes
checking whether /usr/bin/clang accepts -g... yes
checking for /usr/bin/clang option to accept ISO C89... none needed
checking for /usr/bin/clang option to accept ISO C99... none needed
checking whether we are using the GNU C++ compiler... yes
checking whether /usr/bin/clang++ accepts -g... yes
checking for gawk... gawk
checking whether /usr/bin/clang supports -Wdeclaration-after-statement, for CFLAGS... yes
checking whether /usr/bin/clang supports -Werror=vla, for CFLAGS... yes
checking whether /usr/bin/clang supports -Wendif-labels, for CFLAGS... yes
checking whether /usr/bin/clang++ supports -Wendif-labels, for CXXFLAGS... yes
checking whether /usr/bin/clang supports -Wmissing-format-attribute, for CFLAGS... yes
checking whether /usr/bin/clang++ supports -Wmissing-format-attribute, for CXXFLAGS... yes
checking whether /usr/bin/clang supports -Wimplicit-fallthrough=3, for CFLAGS... no
checking whether /usr/bin/clang++ supports -Wimplicit-fallthrough=3, for CXXFLAGS... no
checking whether /usr/bin/clang supports -Wformat-security, for CFLAGS... yes
checking whether /usr/bin/clang++ supports -Wformat-security, for CXXFLAGS... yes
checking whether /usr/bin/clang supports -fno-strict-aliasing, for CFLAGS... yes
checking whether /usr/bin/clang++ supports -fno-strict-aliasing, for CXXFLAGS... yes
checking whether /usr/bin/clang supports -fwrapv, for CFLAGS... yes
checking whether /usr/bin/clang++ supports -fwrapv, for CXXFLAGS... yes
checking whether /usr/bin/clang supports -fexcess-precision=standard, for CFLAGS... no
checking whether /usr/bin/clang++ supports -fexcess-precision=standard, for CXXFLAGS... no
checking whether /usr/bin/clang supports -funroll-loops, for CFLAGS_VECTOR... yes
checking whether /usr/bin/clang supports -ftree-vectorize, for CFLAGS_VECTOR... no
checking whether /usr/bin/clang supports -Wunused-command-line-argument, for NOT_THE_CFLAGS... yes
checking whether /usr/bin/clang supports -Wformat-truncation, for NOT_THE_CFLAGS... no
checking whether /usr/bin/clang supports -Wstringop-truncation, for NOT_THE_CFLAGS... no
checking whether the C compiler still works... yes
checking how to run the C preprocessor... /usr/bin/clang -E
checking for pkg-config... /opt/local/bin/pkg-config
checking pkg-config is at least version 0.9.0... yes
checking allow thread-safe client libraries... yes
checking whether to build with ICU support... yes
checking for icu-uc icu-i18n... yes
checking whether to build with Tcl... no
checking whether to build Perl modules... no
checking whether to build Python modules... no
checking whether to build with GSSAPI support... yes
checking whether to build with PAM support... no
checking whether to build with BSD Authentication support... no
checking whether to build with LDAP support... no
checking whether to build with Bonjour support... yes
checking whether to build with OpenSSL support... yes
checking whether to build with SELinux support... no
checking whether to build with systemd support... no
checking whether to build with XML support... yes
checking for libxml-2.0 >= 2.6.23... yes
checking for ld used by GCC... /usr/bin/ld
checking if the linker (/usr/bin/ld) is GNU ld... no
checking for ranlib... ranlib
checking for strip... strip
checking whether it is possible to strip libraries... yes
checking for ar... ar
checking for a BSD-compatible install... /usr/bin/install -c
checking for tar... /usr/bin/tar
checking whether ln -s works... yes
checking for a thread-safe mkdir -p... /opt/local/bin/gmkdir -p
checking for bison... /opt/local/bin/bison
configure: using bison (GNU Bison) 3.8.2
checking for flex... /opt/local/bin/flex
configure: using flex 2.6.4
checking for perl... /opt/local/bin/perl
configure: using perl 5.28.3
checking for a sed that does not truncate output... /opt/local/bin/gsed
checking for grep that handles long lines and -e... /opt/local/bin/ggrep
checking for egrep... /opt/local/bin/ggrep -E
checking for ANSI C header files... yes
checking for sys/types.h... yes
checking for sys/stat.h... yes
checking for stdlib.h... yes
checking for string.h... yes
checking for memory.h... yes
checking for strings.h... yes
checking for inttypes.h... yes
checking for stdint.h... yes
checking for unistd.h... yes
checking whether /usr/bin/clang is Clang... yes
checking whether Clang needs flag to prevent "argument unused" warning when linking with -pthread... no
checking for joinable pthread attribute... PTHREAD_CREATE_JOINABLE
checking whether more special flags are required for pthreads... no
checking for PTHREAD_PRIO_INHERIT... yes
checking pthread.h usability... yes
checking pthread.h presence... yes
checking for pthread.h... yes
checking for strerror_r... yes
checking for getpwuid_r... yes
checking for gethostbyname_r... no
checking whether strerror_r returns int... yes
checking for main in -lm... yes
checking for library containing setproctitle... no
checking for library containing dlopen... none required
checking for library containing socket... none required
checking for library containing shl_load... no
checking for library containing getopt_long... none required
checking for library containing shm_open... none required
checking for library containing shm_unlink... none required
checking for library containing clock_gettime... no
checking for library containing fdatasync... none required
checking for library containing sched_yield... none required
checking for library containing gethostbyname_r... no
checking for library containing shmget... none required
checking for library containing backtrace_symbols... none required
checking for library containing readline... -lreadline
checking for inflate in -lz... yes
checking for library containing gss_init_sec_context... -lgssapi_krb5
checking for CRYPTO_new_ex_data in -lcrypto... yes
checking for SSL_new in -lssl... yes
checking for X509_get_signature_nid... yes
checking for OPENSSL_init_ssl... yes
checking for BIO_get_data... yes
checking for BIO_meth_new... yes
checking for ASN1_STRING_get0_data... yes
checking for CRYPTO_lock... no
checking for xmlSaveToBuffer in -lxml2... yes
checking for xsltCleanupGlobals in -lxslt... yes
checking for uuid_generate... yes
checking for stdbool.h that conforms to C99... yes
checking for _Bool... yes
checking atomic.h usability... no
checking atomic.h presence... no
checking for atomic.h... no
checking copyfile.h usability... yes
checking copyfile.h presence... yes
checking for copyfile.h... yes
checking execinfo.h usability... yes
checking execinfo.h presence... yes
checking for execinfo.h... yes
checking getopt.h usability... yes
checking getopt.h presence... yes
checking for getopt.h... yes
checking ifaddrs.h usability... yes
checking ifaddrs.h presence... yes
checking for ifaddrs.h... yes
checking langinfo.h usability... yes
checking langinfo.h presence... yes
checking for langinfo.h... yes
checking mbarrier.h usability... no
checking mbarrier.h presence... no
checking for mbarrier.h... no
checking poll.h usability... yes
checking poll.h presence... yes
checking for poll.h... yes
checking sys/epoll.h usability... no
checking sys/epoll.h presence... no
checking for sys/epoll.h... no
checking sys/event.h usability... yes
checking sys/event.h presence... yes
checking for sys/event.h... yes
checking sys/ipc.h usability... yes
checking sys/ipc.h presence... yes
checking for sys/ipc.h... yes
checking sys/prctl.h usability... no
checking sys/prctl.h presence... no
checking for sys/prctl.h... no
checking sys/procctl.h usability... no
checking sys/procctl.h presence... no
checking for sys/procctl.h... no
checking sys/pstat.h usability... no
checking sys/pstat.h presence... no
checking for sys/pstat.h... no
checking sys/resource.h usability... yes
checking sys/resource.h presence... yes
checking for sys/resource.h... yes
checking sys/select.h usability... yes
checking sys/select.h presence... yes
checking for sys/select.h... yes
checking sys/sem.h usability... yes
checking sys/sem.h presence... yes
checking for sys/sem.h... yes
checking sys/shm.h usability... yes
checking sys/shm.h presence... yes
checking for sys/shm.h... yes
checking sys/sockio.h usability... yes
checking sys/sockio.h presence... yes
checking for sys/sockio.h... yes
checking sys/tas.h usability... no
checking sys/tas.h presence... no
checking for sys/tas.h... no
checking sys/un.h usability... yes
checking sys/un.h presence... yes
checking for sys/un.h... yes
checking termios.h usability... yes
checking termios.h presence... yes
checking for termios.h... yes
checking ucred.h usability... no
checking ucred.h presence... no
checking for ucred.h... no
checking wctype.h usability... yes
checking wctype.h presence... yes
checking for wctype.h... yes
checking for net/if.h... yes
checking for sys/ucred.h... yes
checking for netinet/tcp.h... yes
checking readline/readline.h usability... yes
checking readline/readline.h presence... yes
checking for readline/readline.h... yes
checking readline/history.h usability... yes
checking readline/history.h presence... yes
checking for readline/history.h... yes
checking zlib.h usability... yes
checking zlib.h presence... yes
checking for zlib.h... yes
checking gssapi/gssapi.h usability... yes
checking gssapi/gssapi.h presence... yes
checking for gssapi/gssapi.h... yes
checking openssl/ssl.h usability... yes
checking openssl/ssl.h presence... yes
checking for openssl/ssl.h... yes
checking openssl/err.h usability... yes
checking openssl/err.h presence... yes
checking for openssl/err.h... yes
checking libxml/parser.h usability... yes
checking libxml/parser.h presence... yes
checking for libxml/parser.h... yes
checking libxslt/xslt.h usability... yes
checking libxslt/xslt.h presence... yes
checking for libxslt/xslt.h... yes
checking dns_sd.h usability... yes
checking dns_sd.h presence... yes
checking for dns_sd.h... yes
checking uuid/uuid.h usability... yes
checking uuid/uuid.h presence... yes
checking for uuid/uuid.h... yes
checking whether byte ordering is bigendian... no
checking for inline... inline
checking for printf format archetype... printf
checking for __func__... yes
checking for _Static_assert... yes
checking for typeof... typeof
checking for __builtin_types_compatible_p... yes
checking for __builtin_constant_p... yes
checking for __builtin_unreachable... yes
checking for computed goto support... yes
checking for struct tm.tm_zone... yes
checking for union semun... yes
checking for struct sockaddr_un... yes
checking for struct sockaddr_storage... yes
checking for struct sockaddr_storage.ss_family... yes
checking for struct sockaddr_storage.__ss_family... no
checking for struct sockaddr_storage.ss_len... yes
checking for struct sockaddr_storage.__ss_len... no
checking for struct sockaddr.sa_len... yes
checking for struct addrinfo... yes
checking for locale_t... yes (in xlocale.h)
checking for C/C++ restrict keyword... __restrict
checking for struct cmsgcred... no
checking for struct option... yes
checking for z_streamp... yes
checking whether assembler supports x86_64 popcntq... yes
checking for special C compiler options needed for large files... no
checking for _FILE_OFFSET_BITS value needed for large files... no
checking size of off_t... 0
checking size of bool... 0
checking for int timezone... yes
checking types of arguments for accept()... int, int, struct sockaddr *, socklen_t *
checking whether gettimeofday takes only one argument... no
checking for wcstombs_l declaration... yes (in xlocale.h)
checking for backtrace_symbols... yes
checking for clock_gettime... no
checking for copyfile... yes
checking for fdatasync... yes
checking for getifaddrs... yes
checking for getpeerucred... no
checking for getrlimit... yes
checking for kqueue... yes
checking for mbstowcs_l... yes
checking for memset_s... no
checking for poll... yes
checking for posix_fallocate... no
checking for ppoll... no
checking for pstat... no
checking for pthread_is_threaded_np... yes
checking for readlink... yes
checking for setproctitle... no
checking for setproctitle_fast... no
checking for setsid... yes
checking for shm_open... yes
checking for strchrnul... no
checking for strsignal... yes
checking for symlink... yes
checking for sync_file_range... no
checking for uselocale... yes
checking for wcstombs_l... yes
checking for __builtin_bswap16... no
checking for __builtin_bswap32... yes
checking for __builtin_bswap64... yes
checking for __builtin_clz... yes
checking for __builtin_ctz... yes
checking for __builtin_popcount... yes
checking for _LARGEFILE_SOURCE value needed for large files... no
checking how /usr/bin/clang reports undeclared, standard C functions... warning
checking for posix_fadvise... no
checking whether posix_fadvise is declared... no
checking whether fdatasync is declared... no
checking whether strlcat is declared... yes
checking whether strlcpy is declared... yes
checking whether strnlen is declared... yes
checking whether F_FULLFSYNC is declared... yes
checking whether RTLD_GLOBAL is declared... yes
checking whether RTLD_NOW is declared... yes
checking for struct sockaddr_in6... yes
checking for PS_STRINGS... no
checking for dlopen... yes
checking for explicit_bzero... no
checking for fls... yes
checking for getopt... yes
checking for getpeereid... yes
checking for getrusage... yes
checking for inet_aton... yes
checking for link... yes
checking for mkdtemp... yes
checking for pread... yes
checking for pwrite... yes
checking for random... yes
checking for srandom... yes
checking for strlcat... yes
checking for strlcpy... yes
checking for strnlen... yes
checking for strtof... yes
checking for setenv... yes
checking for unsetenv... yes
checking for getaddrinfo... yes
checking for getopt_long... yes
checking for syslog... yes
checking syslog.h usability... yes
checking syslog.h presence... yes
checking for syslog.h... yes
checking for opterr... yes
checking for optreset... yes
checking for strtoll... yes
checking for strtoull... yes
checking whether strtoll is declared... yes
checking whether strtoull is declared... yes
checking unicode/ucol.h usability... yes
checking unicode/ucol.h presence... yes
checking for unicode/ucol.h... yes
checking for rl_completion_append_character... yes
checking for rl_completion_suppress_quote... yes
checking for rl_filename_quote_characters... yes
checking for rl_filename_quoting_function... yes
checking for rl_completion_matches... yes
checking for rl_filename_completion_function... yes
checking for rl_reset_screen_size... yes
checking for append_history... yes
checking for history_truncate_file... yes
checking test program... failed
configure: error: 
Could not execute a simple test program.  This may be a problem
related to locating shared libraries.  Check the file 'config.log'
for the exact reason.
Command failed:  cd "/opt/local/var/macports/build/_opt_local_var_macports_sources_rsync.macports.org_release_tarballs_ports_databases_postgresql13/postgresql13/work/postgresql-13.4" && ./configure --prefix=/opt/local PG_SYSROOT=disabled --sysconfdir=/opt/local/etc/postgresql13 --bindir=/opt/local/lib/postgresql13/bin --libdir=/opt/local/lib/postgresql13 --includedir=/opt/local/include/postgresql13 --datadir=/opt/local/share/postgresql13 --docdir=/opt/local/share/doc/postgresql13 --mandir=/opt/local/share/man --with-includes=/opt/local/include --with-libraries=/opt/local/lib --with-openssl --with-bonjour --with-readline --with-zlib --with-libxml --with-libxslt --with-gssapi --enable-thread-safety --with-uuid=e2fs --with-icu 
Exit code: 1
Error: Failed to configure postgresql13: consult /opt/local/var/macports/build/_opt_local_var_macports_sources_rsync.macports.org_release_tarballs_ports_databases_postgresql13/postgresql13/work/postgresql-13.4/config.log
Error: Failed to configure postgresql13: configure failure: command execution failed
Error: See /opt/local/var/macports/logs/_opt_local_var_macports_sources_rsync.macports.org_release_tarballs_ports_databases_postgresql13/postgresql13/main.log for details.
Error: Follow https://guide.macports.org/#project.tickets if you believe there is a bug.
bash-3.2$

Attachments (2)

config.log (464.1 KB) - added by RobK88 2 years ago.
config.log
Portfile (6.3 KB) - added by RobK88 2 years ago.
Propoed updated portfile which adds kerberos5 dependency

Download all attachments as: .zip

Change History (9)

comment:1 Changed 2 years ago by RobK88

Please note that this bug may be related to https://trac.macports.org/ticket/63832#ticket

Version 0, edited 2 years ago by RobK88 (next)

comment:2 Changed 2 years ago by RobK88

Summary: Unable to Upgrade postgresql13 on Lion -- Configuration Stage Fails and Also BREAKS sudo portUnable to Upgrade postgresql13 on Lion -- Configuration Stage Fails

comment:3 Changed 2 years ago by ryandesign (Ryan Carsten Schmidt)

Cc: jwa@… removed
Owner: set to jyrkiwahlstedt
Status: newassigned

As the error message says, we'll need to see what's in config.log to know why this failed, so please attach that file.

Changed 2 years ago by RobK88

Attachment: config.log added

config.log

comment:4 Changed 2 years ago by RobK88

OOps. I forgot to attach config.log. Here it is.

comment:5 Changed 2 years ago by ryandesign (Ryan Carsten Schmidt)

Keywords: lion removed
Summary: Unable to Upgrade postgresql13 on Lion -- Configuration Stage Failspostgresql13 depends on kerberos5 without declaring a dependency on it

The config.log shows that the problem is:

dyld: Library not loaded: /opt/local/lib/libcrypto.1.1.dylib
  Referenced from: /opt/local/lib/libgssapi_krb5.2.2.dylib
  Reason: image not found

Therefore, update the port that provides /opt/local/lib/libgssapi_krb5.2.2.dylib first:

$ port provides /opt/local/lib/libgssapi_krb5.2.2.dylib
/opt/local/lib/libgssapi_krb5.2.2.dylib is provided by: kerberos5

The postgresql13 port does not mention that it depends upon kerberos5. It should either do that, or prevent kerberos5 from being used if present; either way, a revision increase is in order. There are other postgresql ports as well; they should all be audited for this problem and fixed as needed.

To avoid this problem until it is fixed, you could upgrade postgresql13 using trace mode to prevent it from finding the undeclared dependencies.

sudo port clean postgresql13
sudo port -t upgrade postgresql13

comment:6 Changed 2 years ago by RobK88

Thanks Ryan.

I was able to upgrade postgresql13 without having to resort to using the trace mode. I just upgraded kerberos5 first.

sudo port upgrade kerberos5
--->  Computing dependencies for kerberos5
--->  Fetching distfiles for kerberos5
--->  Verifying checksums for kerberos5
--->  Extracting kerberos5
--->  Applying patches to kerberos5
--->  Configuring kerberos5
Warning: Configuration logfiles contain indications of -Wimplicit-function-declaration; check that features were not accidentally disabled:
  bswap_64: found in krb5-1.19.2/src/config.log
  bswap_16: found in krb5-1.19.2/src/config.log
--->  Building kerberos5
--->  Staging kerberos5 into destroot                    
--->  Installing kerberos5 @1.19.2_1                     
--->  Cleaning kerberos5
--->  Computing dependencies for kerberos5
--->  Deactivating kerberos5 @1.19.2_0
--->  Cleaning kerberos5
--->  Activating kerberos5 @1.19.2_1
--->  Cleaning kerberos5
--->  Updating database of binaries
--->  Scanning binaries for linking errors
--->  Found 62 broken files, matching files to ports     
--->  Found 10 broken ports, determining rebuild order
You can always run 'port rev-upgrade' again to fix errors.
The following ports will be rebuilt:
 python27 @2.7.18
 python37 @3.7.12
 python38 @3.8.12
 sudo @1.9.8p2
 qpdf @10.3.2
 NetSurf @3.10
 rsync @3.2.3
 libevent @2.1.12
 ntp @4.2.8p15
 postgresql13 @13.4
Continue? [Y/n]: Y
etc
etc
--->  Computing dependencies for postgresql13
--->  Configuring postgresql13
Warning: Configuration logfiles contain indications of -Wimplicit-function-declaration; check that features were not accidentally disabled:
  _mm_crc32_u8: found in postgresql-13.4/config.log
  _mm_crc32_u32: found in postgresql-13.4/config.log
--->  Building postgresql13
--->  Staging postgresql13 into destroot                 
Warning: reinplace s#^([[:space:]]+)LDFLAGS =#\1LDFLAGS +=#g didn't change anything in /opt/local/var/macports/build/_opt_local_var_macports_sources_rsync.macports.org_release_tarballs_ports_databases_postgresql13/postgresql13/work/destroot/opt/local/lib/postgresql13/pgxs/src/Makefile.global
--->  Installing postgresql13 @13.4_2
--->  Cleaning postgresql13
--->  Computing dependencies for postgresql13
--->  Deactivating postgresql13 @13.4_1
--->  Cleaning postgresql13
--->  Activating postgresql13 @13.4_2
--->  Cleaning postgresql13
--->  Updating database of binaries
--->  Scanning binaries for linking errors
etc

Please note that there are warning messages == Warning: Configuration logfiles contain indications of -Wimplicit-function-declaration etc.

I often see these warning messages. Looks like the developer may have forgotten to include or import header files. Please comment on whether I should be reporting these -Wimplicit-function-declaration warning messages.

Changed 2 years ago by RobK88

Attachment: Portfile added

Propoed updated portfile which adds kerberos5 dependency

comment:7 Changed 2 years ago by Jyrki Wahlstedt <jyrki.wahlstedt@…>

Resolution: fixed
Status: assignedclosed

In 68cddf80096cc361100688fc4d312a99c43b5579/macports-ports (master):

postgresql14: version bump to 14.1

Closes: #60154
Closes: #63831

These apply to other version bumps, too

Note: See TracTickets for help on using tickets.