1. 29 Jun, 2021 4 commits
  2. 28 Jun, 2021 9 commits
  3. 27 Jun, 2021 2 commits
    • Tom Lane's avatar
      Remove memory leaks in isolationtester. · 642c0697
      Tom Lane authored
      specscanner.l leaked a kilobyte of memory per token of the spec file.
      Apparently somebody thought that the introductory code block would be
      executed once; but it's once per yylex() call.
      
      A couple of functions in isolationtester.c leaked small amounts of
      memory due to not bothering to free one-time allocations.  Might
      as well improve these so that valgrind gives this program a clean
      bill of health.  Also get rid of an ugly static variable.
      
      Coverity complained about one of the one-time leaks, which led me
      to try valgrind'ing isolationtester, which led to discovery of the
      larger leak.
      642c0697
    • Peter Eisentraut's avatar
      Error message refactoring · c302a613
      Peter Eisentraut authored
      Take some untranslatable things out of the message and replace by
      format placeholders, to reduce translatable strings and reduce
      translation mistakes.
      c302a613
  4. 26 Jun, 2021 4 commits
    • Tom Lane's avatar
      dcffc9ba
    • Tom Lane's avatar
      Remove undesirable libpq dependency on stringinfo.c. · 8ec00dc5
      Tom Lane authored
      Commit c0cb87fb unwisely introduced a dependency on the StringInfo
      machinery in fe-connect.c.  We must not use that in libpq, because
      it will do a summary exit(1) if it hits OOM, and that is not
      appropriate behavior for a general-purpose library.  The goal of
      allowing arbitrary line lengths in service files doesn't seem like
      it's worth a lot of effort, so revert back to the previous method
      of using a stack-allocated buffer and failing on buffer overflow.
      
      This isn't an exact revert though.  I kept that patch's refactoring
      to have a single exit path, as that seems cleaner than having each
      error path know what to do to clean up.  Also, I made the fixed-size
      buffer 1024 bytes not 256, just to push off the need for an expandable
      buffer some more.
      
      There is more to do here; in particular the lack of any mechanical
      check for this type of mistake now seems pretty hazardous.  But this
      fix gets us back to the level of robustness we had in v13, anyway.
      
      Discussion: https://postgr.es/m/daeb22ec6ca8ef61e94d766a9b35fb03cabed38e.camel@vmware.com
      8ec00dc5
    • Michael Paquier's avatar
      Remove non-existing variable reference in MSVC's Solution.pm · d5a2c413
      Michael Paquier authored
      The version string is grabbed from PACKAGE_VERSION in pg_config.h in the
      MSVC build since 8f4fb4c6, but an error message referenced a variable
      that existed before that.  This had no consequences except if one messes
      up enough with the version number of the build.
      
      Author: Anton Voloshin
      Discussion: https://postgr.es/m/af79ee1b-9962-b299-98e1-f90a289e19e6@postgrespro.ru
      Backpatch-through: 13
      d5a2c413
    • Michael Paquier's avatar
      Remove some useless logs from the TAP tests of pgbench · 704e1dbd
      Michael Paquier authored
      002_pgbench_no_server was printing some array pointers instead of the
      actual contents of those arrays for the expected outputs of stdout and
      stderr for a tested command.  This does not add any new information that
      can help with debugging as the test names allow to track failure
      locations, if any.
      
      This commit simply removes those logs as the rest of the printed
      information is redundant with command_checks_all().
      
      Per discussion with Andrew Dunstan and Álvaro Herrera.
      
      Discussion: https://postgr.es/m/YNXNFaG7IgkzZanD@paquier.xyz
      Backpatch-through: 11
      704e1dbd
  5. 25 Jun, 2021 10 commits
  6. 24 Jun, 2021 8 commits
  7. 23 Jun, 2021 3 commits
    • Tom Lane's avatar
      Allow non-quoted identifiers as isolation test session/step names. · a443c1b2
      Tom Lane authored
      For no obvious reason, isolationtester has always insisted that
      session and step names be written with double quotes.  This is
      fairly tedious and does little for test readability, especially
      since the names that people actually choose almost always look
      like normal identifiers.  Hence, let's tweak the lexer to allow
      SQL-like identifiers not only double-quoted strings.
      
      (They're SQL-like, not exactly SQL, because I didn't add any
      case-folding logic.  Also there's no provision for U&"..." names,
      not that anyone's likely to care.)
      
      There is one incompatibility introduced by this change: if you write
      "foo""bar" with no space, that used to be taken as two identifiers,
      but now it's just one identifier with an embedded quote mark.
      
      I converted all the src/test/isolation/ specfiles to remove
      unnecessary double quotes, but stopped there because my
      eyes were glazing over already.
      
      Like 741d7f10, back-patch to all supported branches, so that this
      isn't a stumbling block for back-patching isolation test changes.
      
      Discussion: https://postgr.es/m/759113.1623861959@sss.pgh.pa.us
      a443c1b2
    • Tom Lane's avatar
      Doc: fix confusion about LEAKPROOF in syntax summaries. · 2031e166
      Tom Lane authored
      The syntax summaries for CREATE FUNCTION and allied commands
      made it look like LEAKPROOF is an alternative to
      IMMUTABLE/STABLE/VOLATILE, when of course it is an orthogonal
      option.  Improve that.
      
      Per gripe from aazamrafeeque0.  Thanks to David Johnston for
      suggestions.
      
      Discussion: https://postgr.es/m/162444349581.694.5818572718530259025@wrigleys.postgresql.org
      2031e166
    • Tom Lane's avatar
      Don't assume GSSAPI result strings are null-terminated. · 126cdaf4
      Tom Lane authored
      Our uses of gss_display_status() and gss_display_name() assumed
      that the gss_buffer_desc strings returned by those functions are
      null-terminated.  It appears that they generally are, given the
      lack of field complaints up to now.  However, the available
      documentation does not promise this, and some man pages
      for gss_display_status() show examples that rely on the
      gss_buffer_desc.length field instead of expecting null
      termination.  Also, we now have a report that on some
      implementations, clang's address sanitizer is of the opinion
      that the byte after the specified length is undefined.
      
      Hence, change the code to rely on the length field instead.
      
      This might well be cosmetic rather than fixing any real bug, but
      it's hard to be sure, so back-patch to all supported branches.
      While here, also back-patch the v12 changes that made pg_GSS_error
      deal honestly with multiple messages available from
      gss_display_status.
      
      Per report from Sudheer H R.
      
      Discussion: https://postgr.es/m/5372B6D4-8276-42C0-B8FB-BD0918826FC3@tekenlight.com
      126cdaf4