1. 22 Apr, 2021 4 commits
    • Tom Lane's avatar
      Doc: document the tie-breaking behavior of the round() function. · 82b13dbc
      Tom Lane authored
      Back-patch to v13; the table layout in older branches is unfriendly
      to adding such details.
      
      Laurenz Albe
      
      Discussion: https://postgr.es/m/161881920775.685.12293798764864559341@wrigleys.postgresql.org
      82b13dbc
    • Andrew Dunstan's avatar
      Make PostgresNode version aware · 4c4eaf3d
      Andrew Dunstan authored
      A new PostgresVersion object type is created and this is used in
      PostgresNode using the output of `pg_config --version` and the result
      stored in the PostgresNode object.  This object can be compared to other
      PostgresVersion objects, or to a number or string.
      
      PostgresNode is currently believed to be compatible with versions down
      to release 12, so PostgresNode will issue a warning if used with a
      version prior to that.
      
      No attempt has been made to deal with incompatibilities in older
      versions - that remains work to be undertaken in a subsequent
      development cycle.
      
      Based on code from Mark Dilger and Jehan-Guillaume de Rorthais.
      
      Discussion: https://postgr.es/m/a80421c0-3d7e-def1-bcfe-24777f15e344@dunslane.net
      4c4eaf3d
    • Michael Paquier's avatar
      Fix relation leak for subscribers firing triggers in logical replication · f3b141c4
      Michael Paquier authored
      Creating a trigger on a relation to which an apply operation is
      triggered would cause a relation leak once the change gets committed,
      as the executor would miss that the relation needs to be closed
      beforehand.  This issue got introduced with the refactoring done in
      1375422c, where it becomes necessary to track relations within
      es_opened_result_relations to make sure that they are closed.
      
      We have discussed using ExecInitResultRelation() coupled with
      ExecCloseResultRelations() for the relations in need of tracking by the
      apply operations in the subscribers, which would simplify greatly the
      opening and closing of indexes, but this requires a larger rework and
      reorganization of the worker code, particularly for the tuple routing
      part.  And that's not really welcome post feature freeze.  So, for now,
      settle down to the same solution as TRUNCATE which is to fill in
      es_opened_result_relations with the relation opened, to make sure that
      ExecGetTriggerResultRel() finds them and that they get closed.
      
      The code is lightly refactored so as a relation is not registered three
      times for each DML code path, making the whole a bit easier to follow.
      
      Reported-by: Tang Haiying, Shi Yu, Hou Zhijie
      Author: Amit Langote, Masahiko Sawada, Hou Zhijie
      Reviewed-by: Amit Kapila, Michael Paquier
      Discussion: https://postgr.es/m/OS0PR01MB611383FA0FE92EB9DE21946AFB769@OS0PR01MB6113.jpnprd01.prod.outlook.com
      f3b141c4
    • Michael Paquier's avatar
      doc: Move parallel_leader_participation to its correct category · 1599e7b3
      Michael Paquier authored
      parallel_leader_participation got introduced in e5253fdc, where it was
      listed under RESOURCES_ASYNCHRONOUS in guc.c, but the documentation
      did not reflect that and listed it with the other planner-related
      options.  This commit fixes this inconsistency as the parameter is
      intended to be an asynchronous one.
      
      While on it, reorganize a bit the section dedicated to asynchronous
      parameters, backend_flush_after being moved first to do better in terms
      of alphabetical order of the options listed.
      
      Reported-by: Yanliang Lei
      Author: Bharath Rupireddy
      Discussion: https://postgr.es/m/16972-42d4b0c15aa1d5f5@postgresql.org
      1599e7b3
  2. 21 Apr, 2021 12 commits
  3. 20 Apr, 2021 9 commits
    • Tom Lane's avatar
      Improve WAL record descriptions for SP-GiST records. · 783be78c
      Tom Lane authored
      While tracking down the bug fixed in the preceding commit, I got quite
      annoyed by the low quality of spg_desc's output.  Add missing fields,
      try to make the formatting consistent.
      783be78c
    • Tom Lane's avatar
      Fix under-parenthesized XLogRecHasBlockRef() macro. · 9e411482
      Tom Lane authored
      Commit f003d9f8 left this macro with inadequate (or, one could say,
      too much) parenthesization.  Which was catastrophic to the correctness
      of calls such as "if (!XLogRecHasBlockRef(record, 1)) ...".  There
      are only a few of those, which perhaps explains why we didn't notice
      immediately (with our general weakness of WAL replay testing being
      another factor).  I found it by debugging intermittent replay failures
      like
      
      2021-04-08 14:33:30.191 EDT [29463] PANIC:  failed to locate backup block with ID 1
      2021-04-08 14:33:30.191 EDT [29463] CONTEXT:  WAL redo at 0/95D3438 for SPGist/ADD_NODE: off 1; blkref #0: rel 1663/16384/25998, blk 1
      9e411482
    • Bruce Momjian's avatar
      Fix interaction of log_line_prefix's query_id and log_statement · db01f797
      Bruce Momjian authored
      log_statement is issued before query_id can be computed, so properly
      clear the value, and document the interaction.
      
      Reported-by: Fujii Masao, Michael Paquier
      
      Discussion: https://postgr.es/m/YHPkU8hFi4no4NSw@paquier.xyz
      
      Author: Julien Rouhaud
      db01f797
    • Bruce Momjian's avatar
      adjust query id feature to use pg_stat_activity.query_id · 9660834d
      Bruce Momjian authored
      Previously, it was pg_stat_activity.queryid to match the
      pg_stat_statements queryid column.  This is an adjustment to patch
      4f0b0966.  This also adjusts some of the internal function calls to
      match.  Catversion bumped.
      
      Reported-by: Álvaro Herrera, Julien Rouhaud
      
      Discussion: https://postgr.es/m/20210408032704.GA7498@alvherre.pgsql
      9660834d
    • Tom Lane's avatar
      Rename find_em_expr_usable_for_sorting_rel. · 76453767
      Tom Lane authored
      I didn't particularly like this function name, as it fails to
      express what's going on.  Also, returning the sort expression
      alone isn't too helpful --- typically, a caller would also
      need some other fields of the EquivalenceMember.  But the
      sole caller really only needs a bool result, so let's make
      it "bool relation_can_be_sorted_early()".
      
      Discussion: https://postgr.es/m/91f3ec99-85a4-fa55-ea74-33f85a5c651f@swarm64.com
      76453767
    • Tom Lane's avatar
      Fix planner failure in some cases of sorting by an aggregate. · 37539824
      Tom Lane authored
      An oversight introduced by the incremental-sort patches caused
      "could not find pathkey item to sort" errors in some situations
      where a sort key involves an aggregate or window function.
      
      The basic problem here is that find_em_expr_usable_for_sorting_rel
      isn't properly modeling what prepare_sort_from_pathkeys will do
      later.  Rather than hoping we can keep those functions in sync,
      let's refactor so that they actually share the code for
      identifying a suitable sort expression.
      
      With this refactoring, tlist.c's tlist_member_ignore_relabel
      is unused.  I removed it in HEAD but left it in place in v13,
      in case any extensions are using it.
      
      Per report from Luc Vlaming.  Back-patch to v13 where the
      problem arose.
      
      James Coleman and Tom Lane
      
      Discussion: https://postgr.es/m/91f3ec99-85a4-fa55-ea74-33f85a5c651f@swarm64.com
      37539824
    • Andrew Dunstan's avatar
      Avoid unfortunate IPC::Run path caching in PostgresNode · 95c3a195
      Andrew Dunstan authored
      Commit b34ca595 provided for installation-aware instances of
      PostgresNode. However, it turns out that IPC::Run works against this by
      caching the path to a binary and not consulting the path again, even if
      it has changed. We work around this by calling Postgres binaries with
      the installed path rather than just a bare name to be looked up in the
      environment path, if there is an installed path. For the common case
      where there is no installed path we continue to use the bare command
      name.
      
      Diagnosis and solution from Mark Dilger
      
      Discussion: https://postgr.es/m/E8F512F8-B4D6-4514-BA8D-2E671439DA92@enterprisedb.com
      95c3a195
    • Magnus Hagander's avatar
      Fix typo in comment · 8b4b5669
      Magnus Hagander authored
      Author: Julien Rouhaud
      Backpatch-through: 11
      Discussion: https://postgr.es/m/20210420121659.odjueyd4rpilorn5@nol
      8b4b5669
    • Peter Geoghegan's avatar
      Document LP_DEAD accounting issues in VACUUM. · 7136bf34
      Peter Geoghegan authored
      Document VACUUM's soft assumption that any LP_DEAD items encountered
      during pruning will become LP_UNUSED items before VACUUM finishes up.
      This is integral to the accounting used by VACUUM to generate its final
      report on the table to the stats collector.  It also affects how VACUUM
      determines which heap pages are truncatable.  In both cases VACUUM is
      concerned with the likely contents of the page in the near future, not
      the current contents of the page.
      
      This state of affairs created the false impression that VACUUM's dead
      tuple accounting had significant difference with similar accounting used
      during ANALYZE.  There were and are no substantive differences, at least
      when the soft assumption completely works out.  This is far clearer now.
      
      Also document cases where things don't quite work out for VACUUM's dead
      tuple accounting.  It's possible that a significant number of LP_DEAD
      items will be left behind by VACUUM, and won't be recorded as remaining
      dead tuples in VACUUM's statistics collector report.  This behavior
      dates back to commit a96c41fe, which taught VACUUM to run without index
      and heap vacuuming at the user's request.  The failsafe mechanism added
      to VACUUM more recently by commit 1e55e7d1 takes the same approach to
      dead tuple accounting.
      Reported-By: default avatarMasahiko Sawada <sawada.mshk@gmail.com>
      Discussion: https://postgr.es/m/CAH2-Wz=Jmtu18PrsYq3EvvZJGOmZqSO2u3bvKpx9xJa5uhNp=Q@mail.gmail.com
      7136bf34
  4. 19 Apr, 2021 4 commits
  5. 18 Apr, 2021 2 commits
  6. 17 Apr, 2021 3 commits
    • Peter Eisentraut's avatar
      f7c09706
    • Peter Eisentraut's avatar
      Use correct format placeholder for block numbers · f59b58e2
      Peter Eisentraut authored
      Should be %u rather than %d.
      f59b58e2
    • Tom Lane's avatar
      Rethink extraction of collation dependencies. · f24b1569
      Tom Lane authored
      As it stands, find_expr_references_walker() pays attention to leaf-node
      collation fields while ignoring the input collations of actual function
      and operator nodes.  That seems exactly backwards from a semantic
      standpoint, and it leads to reporting dependencies on collations that
      really have nothing to do with the expression's behavior.
      
      Hence, rewrite to look at function input collations instead.  This
      isn't completely perfect either; it fails to account for the behavior
      of record_eq and its siblings.  (The previous coding at least gave an
      approximation of that, though I think it could be fooled pretty easily
      into considering the columns of irrelevant composite types.)  We may
      be able to improve on this later, but for now this should satisfy the
      buildfarm members that didn't like ef387bed.
      
      In passing fix some oversights in GetTypeCollations(), and get
      rid of its duplicative de-duplications.  (I'm worried that it's
      still potentially O(N^2) or worse, but this makes it a little
      better.)
      
      Discussion: https://postgr.es/m/3564817.1618420687@sss.pgh.pa.us
      f24b1569
  7. 16 Apr, 2021 6 commits
    • Tom Lane's avatar
      Update dummy prosrc values. · 8a2df442
      Tom Lane authored
      Ooops, forgot to s/system_views.sql/system_functions.sql/g
      in this part of 767982e3.
      
      No need for an additional catversion bump, I think, since
      these strings are gone by the time initdb finishes.
      
      Discussion: https://postgr.es/m/3956760.1618529139@sss.pgh.pa.us
      8a2df442
    • Tom Lane's avatar
      Convert built-in SQL-language functions to SQL-standard-body style. · 767982e3
      Tom Lane authored
      Adopt the new pre-parsed representation for all built-in and
      information_schema SQL-language functions, except for a small
      number that can't presently be converted because they have
      polymorphic arguments.
      
      This eliminates residual hazards around search-path safety of
      these functions, and might provide some small performance benefits
      by reducing parsing costs.  It seems useful also to provide more
      test coverage for the SQL-standard-body feature.
      
      Discussion: https://postgr.es/m/3956760.1618529139@sss.pgh.pa.us
      767982e3
    • Tom Lane's avatar
      Split function definitions out of system_views.sql into a new file. · e8094937
      Tom Lane authored
      Invent system_functions.sql to carry the function definitions that
      were formerly in system_views.sql.  The function definitions were
      already a quarter of the file and are about to be more, so it seems
      appropriate to give them their own home.
      
      In passing, fix an oversight in dfb75e47: it neglected to call
      check_input() for system_constraints.sql.
      
      Discussion: https://postgr.es/m/3956760.1618529139@sss.pgh.pa.us
      e8094937
    • Andrew Dunstan's avatar
      Allow TestLib::slurp_file to skip contents, and use as needed · 3c5b0685
      Andrew Dunstan authored
      In order to avoid getting old logfile contents certain functions in
      PostgresNode were doing one of two things. On Windows it rotated the
      logfile and restarted the server, while elsewhere it truncated the log
      file. Both of these are unnecessary. We borrow from the buildfarm which
      does this instead: note the size of the logfile before we start, and
      then when fetching the logfile skip to that position before accumulating
      contents. This is spelled differently on Windows but the effect is the
      same. This is largely centralized in TestLib's slurp_file function,
      which has a new optional parameter, the offset to skip to before
      starting to reading the file. Code in the client becomes much neater.
      
      Backpatch to all live branches.
      
      Michael Paquier, slightly modified by me.
      
      Discussion: https://postgr.es/m/YHajnhcMAI3++pJL@paquier.xyz
      3c5b0685
    • Tom Lane's avatar
      Fix bogus collation-version-recording logic. · ef387bed
      Tom Lane authored
      recordMultipleDependencies had the wrong scope for its "version"
      variable, allowing a version label to leak from the collation entry it
      was meant for to subsequent non-collation entries.  This is relatively
      hard to trigger because of the OID-descending order that the inputs
      will normally arrive in: subsequent non-collation items will tend to
      be pinned.  But it can be exhibited easily with a custom collation.
      
      Also, don't special-case the default collation, but instead ignore
      pinned-ness of a collation when we've found a version for it.  This
      avoids creating useless pg_depend entries, and removes a not-very-
      future-proof assumption that C, POSIX, and DEFAULT are the only
      pinned collations.
      
      A small problem is that, because the default collation may or may
      not have a version, the regression tests can't assume anything about
      whether dependency entries will be made for it.  This seems OK though
      since it's now handled just the same as other collations, and we have
      test cases for both versioned and unversioned collations.
      
      Fixes oversights in commit 257836a7.  Thanks to Julien Rouhaud
      for review.
      
      Discussion: https://postgr.es/m/3564817.1618420687@sss.pgh.pa.us
      ef387bed
    • Tom Lane's avatar
      Fix wrong units in two ExplainPropertyFloat calls. · f90c708a
      Tom Lane authored
      This is only a latent bug, since these calls are only reached for
      non-text output formats, and currently none of those will print
      the units.  Still, we should get it right in case that ever changes.
      
      Justin Pryzby
      
      Discussion: https://postgr.es/m/20210415163846.GA3315@telsasoft.com
      f90c708a