reshke opened a new pull request, #1614:
URL: https://github.com/apache/cloudberry/pull/1614

   When the relkind of a relache entry changes, because a table is converted 
into a view, pgstats can get confused in 15+, leading to crashes or assertion 
failures.
   
   For HEAD, Tom fixed this in b23cd185fd5, by removing support for converting 
a table to a view, removing the source of the inconsistency. This commit just 
adds an assertion that a relcache entry's relkind does not change, just in case 
we end up with another case of that in the future. As there's no cases of 
changing relkind anymore, we can't add a test that that's handled correctly.
   
   For 15, fix the problem by not maintaining the association with the old 
pgstat entry when the relkind changes during a relcache invalidation 
processing. In that case the pgstat entry needs to be unlinked first, to avoid 
PgStat_TableStatus->relation getting out of sync. Also add a test reproducing 
the issues.
   
   No known problem exists in 11-14, so just add the test there.
   
   Reported-by: vignesh C <[email protected]>
   Author: Andres Freund <[email protected]>
   Reviewed-by: Tom Lane <[email protected]>
   Discussion: 
https://postgr.es/m/caldanm2yxz+zotv7y5zbd5wkt8o0ld3yxikuu3dcycvxf7g...@mail.gmail.com
   Discussion: 
https://postgr.es/m/caldanm3oza-8wbps2jd1g5_gjrr-x3ywrjpek-mf5asrrvz...@mail.gmail.com
   Backpatch: 15-
   
   <!-- Thank you for your contribution to Apache Cloudberry (Incubating)! -->
   
   Fixes #ISSUE_Number
   
   ### What does this PR do?
   <!-- Brief overview of the changes, including any major features or fixes -->
   
   ### Type of Change
   - [ ] Bug fix (non-breaking change)
   - [ ] New feature (non-breaking change)
   - [ ] Breaking change (fix or feature with breaking changes)
   - [ ] Documentation update
   
   ### Breaking Changes
   <!-- Remove if not applicable. If yes, explain impact and migration path -->
   
   ### Test Plan
   <!-- How did you test these changes? -->
   - [ ] Unit tests added/updated
   - [ ] Integration tests added/updated
   - [ ] Passed `make installcheck`
   - [ ] Passed `make -C src/test installcheck-cbdb-parallel`
   
   ### Impact
   <!-- Remove sections that don't apply -->
   **Performance:**
   <!-- Any performance implications? -->
   
   **User-facing changes:**
   <!-- Any changes visible to users? -->
   
   **Dependencies:**
   <!-- New dependencies or version changes? -->
   
   ### Checklist
   - [ ] Followed [contribution 
guide](https://cloudberry.apache.org/contribute/code)
   - [ ] Added/updated documentation
   - [ ] Reviewed code for security implications
   - [ ] Requested review from [cloudberry 
committers](https://github.com/orgs/apache/teams/cloudberry-committers)
   
   ### Additional Context
   <!-- Any other information that would help reviewers? Remove if none -->
   
   ### CI Skip Instructions
   <!--
   To skip CI builds, add the appropriate CI skip identifier to your PR title.
   The identifier must:
   - Be in square brackets []
   - Include the word "ci" and either "skip" or "no"
   - Only use for documentation-only changes or when absolutely necessary
   -->
   
   ---
   <!-- Join our community:
   - Mailing list: 
[[email protected]](https://lists.apache.org/[email protected])
 (subscribe: [email protected])
   - Discussions: https://github.com/apache/cloudberry/discussions -->
   


-- 
This is an automated message from the Apache Git Service.
To respond to the message, please log on to GitHub and use the
URL above to go to the specific comment.

To unsubscribe, e-mail: [email protected]

For queries about this service, please contact Infrastructure at:
[email protected]


---------------------------------------------------------------------
To unsubscribe, e-mail: [email protected]
For additional commands, e-mail: [email protected]

Reply via email to