1. 14 Oct, 2019 1 commit
    • Tomas Vondra's avatar
      Check for tables with sql_identifier during pg_upgrade · 0ccfc282
      Tomas Vondra authored
      Commit 7c15cef8 changed sql_identifier data type to be based on name
      instead of varchar.  Unfortunately, this breaks on-disk format for this
      data type.  Luckily, that should be a very rare problem, as this data
      type is used only in information_schema views, so this only affects user
      objects (tables, materialized views and indexes).  One way to end in
      such situation is to do CTAS with a query on those system views.
      
      There are two options to deal with this - we can either abort pg_upgrade
      if there are user objects with sql_identifier columns in pg_upgrade, or
      we could replace the sql_identifier type with varchar.  Considering how
      rare the issue is expected to be, and the complexity of replacing the
      data type (e.g. in matviews), we've decided to go with the simple check.
      
      The query is somewhat complex - the sql_identifier data type may be used
      indirectly - through a domain, a composite type or both, possibly in
      multiple levels.  Detecting this requires a recursive CTE.
      
      Backpatch to 12, where the sql_identifier definition changed.
      
      Reported-by: Hans Buschmann
      Author: Tomas Vondra
      Reviewed-by: Tom Lane
      Backpatch-to: 12
      Discussion: https://postgr.es/m/16045-673e8fa6b5ace196%40postgresql.org
      0ccfc282
  2. 13 Oct, 2019 5 commits
    • Michael Paquier's avatar
      Update test output of sepgsql for ALTER TABLE COLUMN DROP · 14ac4237
      Michael Paquier authored
      1df5875d has changed the way dependencies are dropped for this command
      with inheritance trees, which impacts sepgsql.  This just updates the
      regression test output to take care of the failures and adapt to the new
      code.
      
      Reported by buildfarm member rhinoceros.
      
      Author: Michael Paquier
      Reviewed-by: Tom Lane
      Discussion: https://postgr.es/m/20191013101331.GC1434@paquier.xyz
      Backpatch-through: 12
      14ac4237
    • Peter Eisentraut's avatar
      Update unicode.org URLs · bdb839cb
      Peter Eisentraut authored
      Use https, consistent host name, remove references to ftp.  Also
      update the URLs for CLDR, which has moved from Trac to GitHub.
      bdb839cb
    • Tom Lane's avatar
      In the postmaster, rely on the signal infrastructure to block signals. · 9abb2bfc
      Tom Lane authored
      POSIX sigaction(2) can be told to block a set of signals while a
      signal handler executes.  Make use of that instead of manually
      blocking and unblocking signals in the postmaster's signal handlers.
      This should save a few cycles, and it also prevents recursive
      invocation of signal handlers when many signals arrive in close
      succession.  We have seen buildfarm failures that seem to be due to
      postmaster stack overflow caused by such recursion (exacerbated by
      a Linux PPC64 kernel bug).
      
      This doesn't change anything about the way that it works on Windows.
      Somebody might consider adjusting port/win32/signal.c to let it work
      similarly, but I'm not in a position to do that.
      
      For the moment, just apply to HEAD.  Possibly we should consider
      back-patching this, but it'd be good to let it age awhile first.
      
      Discussion: https://postgr.es/m/14878.1570820201@sss.pgh.pa.us
      9abb2bfc
    • Tom Lane's avatar
      Revert "Hack pg_ctl to report postmaster's exit status." · f38291e9
      Tom Lane authored
      This reverts commit 6a5084ee.
      We learned what we needed to know from that.
      f38291e9
    • Michael Paquier's avatar
      Fix dependency handling of column drop with partitioned tables · 1df5875d
      Michael Paquier authored
      When dropping a column on a partitioned table which has one or more
      partitioned indexes, the operation was failing as dependencies with
      partitioned indexes using the column dropped were not getting removed in
      a way consistent with the columns involved across all the relations part
      of an inheritance tree.
      
      This commit refactors the code executing column drop so as all the
      columns from an inheritance tree to remove are gathered first, and
      dropped all at the end.  This way, we let the dependency machinery sort
      out by itself the deletion of all the columns with the partitioned
      indexes across a partition tree.
      
      This issue has been introduced by 1d92a0c9, so backpatch down to
      REL_12_STABLE.
      
      Author: Amit Langote, Michael Paquier
      Reviewed-by: Álvaro Herrera, Ashutosh Sharma
      Discussion: https://postgr.es/m/CA+HiwqE9kuBsZ3b5pob2-cvE8ofzPWs-og+g8bKKGnu6b4-yTQ@mail.gmail.com
      Backpatch-through: 12
      1df5875d
  3. 12 Oct, 2019 2 commits
  4. 11 Oct, 2019 1 commit
  5. 10 Oct, 2019 3 commits
  6. 09 Oct, 2019 5 commits
  7. 08 Oct, 2019 4 commits
  8. 07 Oct, 2019 9 commits
  9. 06 Oct, 2019 2 commits
    • Tom Lane's avatar
      Doc: improve docs about pg_statistic_ext_data. · 732457b5
      Tom Lane authored
      Commit aa087ec6 was a bit over-hasty about the doc changes needed
      while splitting pg_statistic_ext_data off from pg_statistic_ext.
      It duplicated one para and inserted another in what seems to me
      to be the wrong section.  Fix that up, and in passing do some minor
      copy-editing.
      
      Per report from noborusai.
      
      Discussion: https://postgr.es/m/CAAM3qnLXLUz4mOBkqa8jxigpKhKNxzSuvwpjvCRPvO5EqWjxSg@mail.gmail.com
      732457b5
    • Tom Lane's avatar
      Avoid trying to release a List's initial allocation via repalloc(). · ac12ab06
      Tom Lane authored
      Commit 1cff1b95 included some code that supposed it could repalloc()
      a memory chunk to a smaller size without risk of the chunk moving.
      That was not a great idea, because it depended on undocumented behavior
      of AllocSetRealloc, which commit c477f3e4 changed thereby breaking it.
      (Not to mention that this code ought to work with other memory context
      types, which might not work the same...)  So get rid of the repalloc
      calls, and instead just wipe the now-unused ListCell array and/or tell
      Valgrind it's NOACCESS, as if we'd freed it.
      
      In cases where the initial list allocation had been quite large, this
      could represent an annoying waste of space.  In principle we could
      ameliorate that by allocating the initial cell array separately when
      it exceeds some threshold.  But that would complicate new_list() which
      is hot code, and the returns would materialize only in narrow cases.
      On balance I don't think it'd be worth it.
      
      Discussion: https://postgr.es/m/17059.1570208426@sss.pgh.pa.us
      ac12ab06
  10. 05 Oct, 2019 5 commits
  11. 04 Oct, 2019 3 commits
    • Andres Freund's avatar
      Add isolation tests for the combination of EPQ and triggers. · c8841199
      Andres Freund authored
      As evidenced by bug #16036 this area is woefully under-tested. Add
      fairly extensive tests for the combination.
      
      Backpatch back to 9.6 - before that isolationtester was not capable
      enough. While we don't backpatch tests all the time, future fixes to
      trigger.c would potentially look different enough in 12+ from the
      earlier branches that introducing bugs during backpatching is more
      likely than normal. Also, it's just a crucial and undertested area of
      the code.
      
      Author: Andres Freund
      Discussion: https://postgr.es/m/16036-28184c90d952fb7f@postgresql.org
      Backpatch: 9.6-, the earliest these tests work
      c8841199
    • Andres Freund's avatar
      Fix crash caused by EPQ happening with a before update trigger present. · d986d4e8
      Andres Freund authored
      When ExecBRUpdateTriggers()'s GetTupleForTrigger() follows an EPQ
      chain the former needs to run the result tuple through the junkfilter
      again, and update the slot containing the new version of the tuple to
      contain that new version. The input tuple may already be in the
      junkfilter's output slot, which used to be OK - we don't need the
      previous version anymore. Unfortunately ff11e7f4 started to use
      ExecCopySlot() to update newslot, and ExecCopySlot() doesn't support
      copying a slot into itself, leading to a slot in a corrupt
      state, which then can cause crashes or other symptoms.
      
      Fix this by skipping the ExecCopySlot() when copying into itself.
      
      While we could have easily made ExecCopySlot() handle that case, it
      seems better to add an assert forbidding doing so instead. As the goal
      of copying might be to make the contents of one slot independent from
      another, it seems failure prone to handle doing so silently.
      
      A follow-up commit will add tests for the obviously under-covered
      combination of EPQ and triggers. Done as a separate commit as it might
      make sense to backpatch them further than this bug.
      
      Also remove confusion with confusing variable names for slots in
      ExecBRDeleteTriggers() and ExecBRUpdateTriggers().
      
      Bug: #16036
      Reported-By: Антон Власов
      Author: Andres Freund
      Discussion: https://postgr.es/m/16036-28184c90d952fb7f@postgresql.org
      Backpatch: 12-, where ff11e7f4 was merged
      d986d4e8
    • Andres Freund's avatar
      Use a fd opened for read/write when syncing slots during startup, take 2. · a586cc4b
      Andres Freund authored
      Cribbing from dfbaed45:
          Some operating systems, including the reporter's windows, return EBADFD
          or similar when fsync() is invoked on a O_RDONLY file descriptor.
          Unfortunately RestoreSlotFromDisk() does exactly that; which causes
          failures after restarts in at least some scenarios.
      
          If you hit the bug the error message will be something like
          ERROR: could not fsync file "pg_replslot/$name/state": Bad file descriptor
      
          Simply use O_RDWR instead of O_RDONLY when opening the relevant file
          descriptor to fix the bug.
      
      Unfortunately this fix was undone in 82a5649f. Re-apply, and add a
      comment.
      
      Bug: 16039
      Reported-By: Hans Buschmann
      Author: Andres Freund
      Discussion: https://postgr.es/m/16039-196fc97cc05e141c@postgresql.org
      Backpatch: 12-, as 82a5649f
      a586cc4b