1. 24 Apr, 2015 10 commits
    • Noah Misch's avatar
      Remove obsolete -I options from ECPG library compilation. · c8aa8938
      Noah Misch authored
      The MSVC build system already omitted these.
      c8aa8938
    • Noah Misch's avatar
      Remove superfluous -DFRONTEND. · bcd7e889
      Noah Misch authored
      The majority practice is to add -DFRONTEND in directories building files
      that are, at other times, built for the backend.  Some directories
      lacking that property added a noise -DFRONTEND in one build system.
      Remove the excess flags, for consistency.
      bcd7e889
    • Noah Misch's avatar
      Build every ECPG library with -DFRONTEND. · 151e7471
      Noah Misch authored
      Each of the libraries incorporates src/port files, which often check
      FRONTEND.  Build systems disagreed on whether to build libpgtypes this
      way.  Only libecpg incorporates files that rely on it today.  Back-patch
      to 9.0 (all supported versions) to forestall surprises.
      151e7471
    • Tom Lane's avatar
      Fix up .gitignore and cleanup actions in some src/test/ subdirectories. · 732b33f8
      Tom Lane authored
      examples/, locale/, and thread/ lacked .gitignore files and were also
      not connected up to top-level "make clean" etc.  This had escaped notice
      because none of those directories are built in normal scenarios.  Still,
      they have working Makefiles, so if someone does a "make" in one of these
      directories it would be good if (a) git doesn't bleat about the product
      files and (b) cleaning up removes them.
      
      This is a longstanding oversight, but since this behavior is probably
      only of interest to developers, there seems no need for back-patching.
      
      Michael Paquier and Tom Lane
      732b33f8
    • Tom Lane's avatar
      Fix obsolete comment in set_rel_size(). · 70d44dd9
      Tom Lane authored
      The cross-reference to set_append_rel_pathlist() was obsoleted by
      commit e2fa76d8, which split what
      had been set_rel_pathlist() and child routines into two sets of
      functions.  But I (tgl) evidently missed updating this comment.
      
      Back-patch to 9.2 to avoid unnecessary divergence among branches.
      
      Amit Langote
      70d44dd9
    • Heikki Linnakangas's avatar
    • Peter Eisentraut's avatar
      doc: Move ALTER TABLE IF EXISTS description to better place · d64a9c8c
      Peter Eisentraut authored
      It was previously mixed in with the description of ALTER TABLE
      subcommands.  Move it to the Parameters section, which is where it is on
      other reference pages.
      
      pointed out by Amit Langote
      d64a9c8c
    • Peter Eisentraut's avatar
      Fix misspellings · 9ba978c8
      Peter Eisentraut authored
      Amit Langote and Thom Brown
      9ba978c8
    • Stephen Frost's avatar
      Copy the relation name for error reporting in WCOs · cb087ec0
      Stephen Frost authored
      In get_row_security_policies(), we need to make a copy of the relation
      name when building the WithCheckOptions structure, since
      RelationGetRelationName just returns a pointer into the local Relation
      structure.  The relation name in the WCO structure is only used for
      error reporting.
      
      Pointed out by Robert and Christian Ullrich, who noted that the
      buildfarm members with -DCLOBBER_CACHE_ALWAYS were failing.
      cb087ec0
    • Heikki Linnakangas's avatar
      Move functions related to index maintenance to separate source file. · 62420ae7
      Heikki Linnakangas authored
      There is enough code here to deserve a file of their own, not be buried
      in the middle of execUtils.c.
      62420ae7
  2. 23 Apr, 2015 3 commits
    • Heikki Linnakangas's avatar
      Fix deadlock at startup, if max_prepared_transactions is too small. · 2c47fe16
      Heikki Linnakangas authored
      When the startup process recovers transactions by scanning pg_twophase
      directory, it should clear MyLockedGxact after it's done processing each
      transaction. Like we do during normal operation, at PREPARE TRANSACTION.
      Otherwise, if the startup process exits due to an error, it will try to
      clear the locking_backend field of the last recovered transaction. That's
      usually harmless, but if the error happens in MarkAsPreparing, while
      holding TwoPhaseStateLock, the shmem-exit hook will try to acquire
      TwoPhaseStateLock again, and deadlock with itself.
      
      This fixes bug #13128 reported by Grant McAlister. The bug was introduced
      by commit bb38fb0d, so backpatch to all supported versions like that
      commit.
      2c47fe16
    • Peter Eisentraut's avatar
      Fix shell error on Solaris · 2aa0fb03
      Peter Eisentraut authored
      Apparently, the Bourne shell on Solaris doesn't like "for" loops with an
      empty list, so have "make" skip the loop in that case.
      2aa0fb03
    • Peter Eisentraut's avatar
      Improve speed of make check-world · dcae5fac
      Peter Eisentraut authored
      Before, make check-world would create a new temporary installation for
      each test suite, which is slow and wasteful.  Instead, we now create one
      test installation that is used by all test suites that are part of a
      make run.
      
      The management of the temporary installation is removed from pg_regress
      and handled in the makefiles.  This allows for better control, and
      unifies the code with that of test suites not run through pg_regress.
      
      review and msvc support by Michael Paquier <michael.paquier@gmail.com>
      
      more review by Fabien Coelho <coelho@cri.ensmp.fr>
      dcae5fac
  3. 22 Apr, 2015 7 commits
    • Alvaro Herrera's avatar
      Use the right type OID after creating a shell type · 50a16e30
      Alvaro Herrera authored
      Commit a2e35b53 neglected to update the type OID to use further
      down in DefineType when TypeShellMake was changed to return
      ObjectAddress instead of OID (it got it right in DefineRange, however.)
      This resulted in an internal error message being issued when looking up
      I/O functions.
      
      Author: Michael Paquier
      
      Also add Asserts() to a couple of other places to ensure that the type
      OID being used is as expected.
      50a16e30
    • Stephen Frost's avatar
      Fix installcheck for test_rls_hooks · 450fa1b5
      Stephen Frost authored
      As pointed out by the buildfarm, test_rls_hooks wasn't functioning
      properly with a clean installcheck.  test_rls_hooks needs to explicitly
      load the library with the hooks in it, to allow installcheck to work;
      using the --temp-config doesn't help since that isn't used when running
      installcheck and it isn't exactly fair to the buildfarm to modify the
      installed config prior to calling installcheck.
      
      Also, have test_rls_hooks clean up after itself.
      450fa1b5
    • Stephen Frost's avatar
      RLS fixes, new hooks, and new test module · 0bf22e0c
      Stephen Frost authored
      In prepend_row_security_policies(), defaultDeny was always true, so if
      there were any hook policies, the RLS policies on the table would just
      get discarded.  Fixed to start off with defaultDeny as false and then
      properly set later if we detect that only the default deny policy exists
      for the internal policies.
      
      The infinite recursion detection in fireRIRrules() didn't properly
      manage the activeRIRs list in the case of WCOs, so it would incorrectly
      report infinite recusion if the same relation with RLS appeared more
      than once in the rtable, for example "UPDATE t ... FROM t ...".
      
      Further, the RLS expansion code in fireRIRrules() was handling RLS in
      the main loop through the rtable, which lead to RTEs being visited twice
      if they contained sublink subqueries, which
      prepend_row_security_policies() attempted to handle by exiting early if
      the RTE already had securityQuals.  That doesn't work, however, since
      if the query involved a security barrier view on top of a table with
      RLS, the RTE would already have securityQuals (from the view) by the
      time fireRIRrules() was invoked, and so the table's RLS policies would
      be ignored.  This is fixed in fireRIRrules() by handling RLS in a
      separate loop at the end, after dealing with any other sublink
      subqueries, thus ensuring that each RTE is only visited once for RLS
      expansion.
      
      The inheritance planner code didn't correctly handle non-target
      relations with RLS, which would get turned into subqueries during
      planning. Thus an update of the form "UPDATE t1 ... FROM t2 ..." where
      t1 has inheritance and t2 has RLS quals would fail.  Fix by making sure
      to copy in and update the securityQuals when they exist for non-target
      relations.
      
      process_policies() was adding WCOs to non-target relations, which is
      unnecessary, and could lead to a lot of wasted time in the rewriter and
      the planner. Fix by only adding WCO policies when working on the result
      relation.  Also in process_policies, we should be copying the USING
      policies to the WITH CHECK policies on a per-policy basis, fix by moving
      the copying up into the per-policy loop.
      
      Lastly, as noted by Dean, we were simply adding policies returned by the
      hook provided to the list of quals being AND'd, meaning that they would
      actually restrict records returned and there was no option to have
      internal policies and hook-based policies work together permissively (as
      all internal policies currently work).  Instead, explicitly add support
      for both permissive and restrictive policies by having a hook for each
      and combining the results appropriately.  To ensure this is all done
      correctly, add a new test module (test_rls_hooks) to test the various
      combinations of internal, permissive, and restrictive hook policies.
      
      Largely from Dean Rasheed (thanks!):
      
      CAEZATCVmFUfUOwwhnBTcgi6AquyjQ0-1fyKd0T3xBWJvn+xsFA@mail.gmail.com
      
      Author: Dean Rasheed, though I added the new hooks and test module.
      0bf22e0c
    • Stephen Frost's avatar
      Pull in tableoid for inheiritance with rowMarks · 4ccc5bd2
      Stephen Frost authored
      As noted by Etsuro Fujita [1] and Dean Rasheed[2],
      cb1ca4d8 changed ExecBuildAuxRowMark()
      to always look for the tableoid in the target list, but didn't also
      change preprocess_targetlist() to always include the tableoid.  This
      resulted in errors with soon-to-be-added RLS with inheritance tests,
      and errors when using inheritance with foreign tables.
      
      Authors: Etsuro Fujita and Dean Rasheed (independently)
      
      Minor word-smithing on the comments by me.
      
      [1] 552CF0B6.8010006@lab.ntt.co.jp
      [2] CAEZATCVmFUfUOwwhnBTcgi6AquyjQ0-1fyKd0T3xBWJvn+xsFA@mail.gmail.com
      4ccc5bd2
    • Heikki Linnakangas's avatar
      Make the pg_rewind regression tests more robust on slow systems. · 54a16df0
      Heikki Linnakangas authored
      There were a couple of hard-coded sleeps in the tests: to wait for standby
      to catch up with master, and to wait for promotion with "pg_ctl promote"
      to complete. Instead of a fixed, hard-coded sleep, poll the server with a
      query once a second. This isn't ideal either, and I wish we had a better
      solution for real-world applications too, but this should fix the
      immediate problem.
      
      Patch by Michael Paquier, with some editing by me.
      54a16df0
    • Andres Freund's avatar
      Rename pg_replication_slot's new active_in to active_pid. · cef939c3
      Andres Freund authored
      In d811c037 active_in was added but discussion since showed that
      active_pid is preferred as a name.
      
      Discussion: CAMsr+YFKgZca5_7_ouaMWxA5PneJC9LNViPzpDHusaPhU9pA7g@mail.gmail.com
      cef939c3
    • Heikki Linnakangas's avatar
  4. 21 Apr, 2015 5 commits
  5. 20 Apr, 2015 2 commits
  6. 18 Apr, 2015 1 commit
  7. 17 Apr, 2015 2 commits
    • Stephen Frost's avatar
      Fix typo in relcache's equalPolicy() · ab6d1cd2
      Stephen Frost authored
      The USING policies were not being checked for differences as the same
      policy was being passed in to both sides of the equal().  This could
      result in backends not realizing that a policy had been changed, if
      none of the other attributes had been changed.
      
      Fix by passing to equal() the policy1 and policy2 using quals for
      comparison.
      
      No need to back-patch as this is not yet released.  Noticed while
      testing changes to RLS proposed by Dean Rasheed.
      ab6d1cd2
    • Alvaro Herrera's avatar
      Add new target modulescheck in vcregress.pl · 4cb7d671
      Alvaro Herrera authored
      This allows an MSVC build to run regression tests related to modules in
      src/test/modules.
      
      Author: Michael Paquier
      Reviewed by: Andrew Dunstan
      4cb7d671
  8. 16 Apr, 2015 5 commits
    • Bruce Momjian's avatar
      pg_upgrade: document need for text search files to be copied · 2e5d52a6
      Bruce Momjian authored
      Report by CJ Estel
      
      Backpatch through 9.4
      2e5d52a6
    • Alvaro Herrera's avatar
      MSVC: install src/test/modules together with contrib · 22d00532
      Alvaro Herrera authored
      These modules have to be installed so that the testing module can access
      them.  (We don't have that yet, but will soon have it.)
      
      Author: Michael Paquier
      Reviewed by: Andrew Dunstan
      22d00532
    • Heikki Linnakangas's avatar
      Fix assertion failure in logical decoding. · e2999abc
      Heikki Linnakangas authored
      Logical decoding set SnapshotData's regd_count field to avoid the
      snapshot manager from prematurely freeing snapshots that are generated
      by the decoding system. That was always an abuse of the field, as it was
      never supposed to be used outside the snapshot manager. Commit 94028691
      made snapshot manager's tracking of the snapshots smarter, and that scheme
      fell apart. The snapshot manager got confused and hit the assertion, when
      a snapshot that was marked with regd_count==1 was not found in the heap,
      where the snapshot manager tracks registered the snapshots.
      
      To fix, don't abuse the regd_count field like that. Logical decoding still
      abuses the active_count field for similar purposes, but that's currently
      harmless.
      
      The assertion failure was first reported by Michael Paquier
      e2999abc
    • Alvaro Herrera's avatar
      MSVC: Include modules of src/test/modules in build · 90898af3
      Alvaro Herrera authored
      commit_ts, being only a module used for test purposes, is ignored in the
      process for now.
      
      Author: Michael Paquier
      Reviewed by: Andrew Dunstan
      90898af3
    • Heikki Linnakangas's avatar
      b5e384e3
  9. 15 Apr, 2015 4 commits
    • Heikki Linnakangas's avatar
      Error out in pg_rewind if lstat() fails. · b5e560c2
      Heikki Linnakangas authored
      A "file not found" is expected if the source server is running, so don't
      complain about that. But any other error is definitely not expected.
      b5e560c2
    • Heikki Linnakangas's avatar
      Minor cleanup of pg_rewind. · 41457fcf
      Heikki Linnakangas authored
      Update comments and function names to use the terms "source" and "target"
      consistently. Some places were calling them remote and local instead, which
      was confusing.
      
      Fix incorrect comment in extractPageInfo on database creation record - it
      was wrong on what happens for databases created in the target that don't
      exist in source.
      41457fcf
    • Heikki Linnakangas's avatar
      Shut down test servers after pg_rewind regression tests. · 0d8a22a9
      Heikki Linnakangas authored
      Now that the test servers are initialized twice in each .pl script,
      the single END block is not enough to stop them. Add a new clean_rewind_test
      function that is called at the end of each test.
      
      Michael Paquier
      0d8a22a9
    • Heikki Linnakangas's avatar
      Fix logic to skip checkpoint if no records have been inserted. · 3d80a1e0
      Heikki Linnakangas authored
      After the WAL format changes, the calculation of the size of a checkpoint
      record became incorrect. Instead of trying to fix the math, check that the
      previous record, i.e. the xl_prev value that we'd write for the next
      record, matches the last checkpoint's redo pointer. That way it's not
      dependent on the size of the checkpoint record at all.
      
      The old logic was actually slightly wrong all along: if the previous
      checkpoint record crossed a page boundary, the page headers threw off the
      record size calculation, and the checkpoint was not skipped. The new
      checkpoint would not cross a page boundary, so this only resulted in at
      most one extra checkpoint after the system became idle. The new logic fixes
      that. (It's not worth fixing in backbranches).
      
      However, it makes some sense to try to keep the latest checkpoint contained
      fully in a page, or at least in a single WAL segment, just on general
      robustness grounds. If something goes awfully wrong, it's more likely that
      you can recover the latest WAL segment, than the last two WAL segments. So
      I added an extra check that the checkpoint is not skipped if the previous
      checkpoint crossed a WAL segment.
      
      Reported by Jeff Janes.
      3d80a1e0
  10. 14 Apr, 2015 1 commit