Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

safekeeper: add membership configuration switch endpoint #10241

Open
wants to merge 1 commit into
base: sk-membership-cf
Choose a base branch
from

Conversation

arssher
Copy link
Contributor

@arssher arssher commented Dec 25, 2024

Problem

#9965

Summary of changes

Add to safekeeper http endpoint to switch membership configuration. Also add it to python client for tests, and add simple test itself.

@arssher arssher requested a review from arpad-m December 25, 2024 13:24
@arssher arssher requested a review from a team as a code owner December 25, 2024 13:24
@arssher arssher changed the base branch from main to sk-membership-cf December 25, 2024 13:24
@arssher arssher force-pushed the sk-membership-switch-ep branch from 060a731 to 0f2c8d9 Compare December 25, 2024 13:30
Copy link

7106 tests run: 6768 passed, 34 failed, 304 skipped (full report)


Failures on Postgres 17

Failures on Postgres 16

Failures on Postgres 15

Failures on Postgres 14

# Run all failed tests locally:
scripts/pytest -vv -n $(nproc) -k "test_forward_compatibility[release-pg14] or test_forward_compatibility[release-pg14] or test_versions_mismatch[release-pg14-combination_ooonn] or test_versions_mismatch[release-pg14-combination_ooonn] or test_versions_mismatch[release-pg14-combination_ononn] or test_versions_mismatch[release-pg14-combination_ononn] or test_forward_compatibility[release-pg15] or test_forward_compatibility[release-pg15] or test_versions_mismatch[release-pg15-combination_ooonn] or test_versions_mismatch[release-pg15-combination_ooonn] or test_versions_mismatch[release-pg15-combination_ononn] or test_versions_mismatch[release-pg15-combination_ononn] or test_forward_compatibility[release-pg16] or test_forward_compatibility[release-pg16] or test_versions_mismatch[release-pg16-combination_ooonn] or test_versions_mismatch[release-pg16-combination_ooonn] or test_versions_mismatch[release-pg16-combination_ononn] or test_versions_mismatch[release-pg16-combination_ononn] or test_forward_compatibility[release-pg17] or test_forward_compatibility[release-pg17] or test_forward_compatibility[debug-pg17] or test_forward_compatibility[release-pg17] or test_forward_compatibility[release-pg17] or test_versions_mismatch[release-pg17-combination_ooonn] or test_versions_mismatch[release-pg17-combination_ooonn] or test_versions_mismatch[debug-pg17-combination_ooonn] or test_versions_mismatch[release-pg17-combination_ooonn] or test_versions_mismatch[release-pg17-combination_ooonn] or test_versions_mismatch[release-pg17-combination_ononn] or test_versions_mismatch[release-pg17-combination_ononn] or test_versions_mismatch[debug-pg17-combination_ononn] or test_versions_mismatch[release-pg17-combination_ononn] or test_versions_mismatch[release-pg17-combination_ononn] or test_idle_checkpoints[debug-pg17]"
Flaky tests (2)

Postgres 15

  • test_pgdata_import_smoke[None-1024-RelBlockSize.MULTIPLE_RELATION_SEGMENTS]: release-arm64

Postgres 14

Test coverage report is not available

The comment gets automatically updated with the latest test results
0f2c8d9 at 2024-12-25T14:26:11.971Z :recycle:

Also add it to python client for tests, and add simple test itself.
@arssher arssher force-pushed the sk-membership-switch-ep branch from 0f2c8d9 to 0f097d5 Compare December 26, 2024 06:02
log.info(f"conf after restart: {after_restart}")
assert after_restart.generation == 4

# Switch into non join conf.
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Suggested change
# Switch into non join conf.
# Switch into disjoint conf.

@@ -170,7 +193,10 @@ def timeline_status(
res.raise_for_status()
resj = res.json()
walreceivers = [Walreceiver(wr["conn_id"], wr["status"]) for wr in resj["walreceivers"]]
# It is always normally not None, it is allowed only to make forward compat tests happy.
mconf = Configuration.from_json(resj["mconf"]) if "mconf" in resj else None
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

This still causes KeyError: 'mconf' to be issued if not present, causing some test failures (see test bot comment above).

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

2 participants