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

ci: parallelize tests more aggressively #124

Draft
wants to merge 7 commits into
base: main
Choose a base branch
from
Draft

Conversation

ushitora-anqou
Copy link
Contributor

@ushitora-anqou ushitora-anqou commented Mar 11, 2025

This PR is a kaizen and should have no functional changes.

This PR parallelizes the e2e multik8s tests by using Ginkgo labels instead of Go packages. See each commit message for the details.

@ushitora-anqou ushitora-anqou force-pushed the ci-parallelize branch 8 times, most recently from 1b1b04b to ea1d154 Compare March 13, 2025 07:25
@ushitora-anqou ushitora-anqou force-pushed the ci-parallelize branch 5 times, most recently from f77bdd3 to 5b702b0 Compare March 25, 2025 04:57
@ushitora-anqou ushitora-anqou requested a review from peng225 March 25, 2025 07:14
@ushitora-anqou ushitora-anqou removed the request for review from peng225 April 1, 2025 09:00
This commit separates the tests in the
test/e2e/multik8s/replication/suite_test.go into 3 different files, i.e.,
full_backup_test.go, incremental_backup_test.go, and misc_test.go. The
tests in each file has each different label ("full-backup",
"incremental-backup", or "misc"), and these labels are used to
parallelize the tests in the CI.

There should be no functional changes in this commit.

Signed-off-by: Ryotaro Banno <[email protected]>
…ckage

The replicationfailure package was made to parallelize the e2e tests.
However, we can use labels for this purpose. This commit moves the tests
in the replicationfailure package to replication package. Instead, it
attaches "backup-failure" label to the tests so that they can run in
parallel.

There should be no functional changes in this commit.

Signed-off-by: Ryotaro Banno <[email protected]>
The changetoprimary package was made to parallelize the e2e tests.
However, we can use labels for this purpose. This commit moves the tests
in the changetoprimary package to replication package. Instead, it
attaches "change-to-primary" label to the tests so that they can run in
parallel.

There should be no functional changes in this commit.

Signed-off-by: Ryotaro Banno <[email protected]>
…kage

The changetosecondary package was made to parallelize the e2e tests.
However, we can use labels for this purpose. This commit moves the tests
in the changetosecondary package to replication package. Instead, it
attaches "change-to-secondary" label to the tests so that they can run
in parallel.

There should be no functional changes in this commit.

Signed-off-by: Ryotaro Banno <[email protected]>
The changetostandalone package was made to parallelize the e2e tests.
However, we can use labels for this purpose. This commit moves the tests
in the changetostandalone package to replication package. Instead, it
attaches "change-to-standalone" label to the tests so that they can run
in parallel.

There should be no functional changes in this commit.

Signed-off-by: Ryotaro Banno <[email protected]>
Copy link

@Copilot Copilot AI left a comment

Choose a reason for hiding this comment

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

Pull Request Overview

This PR reworks the test suite organization for multi‑k8s replication tests by parallelizing the execution through Ginkgo labels rather than Go package grouping, with no intended functional changes. Key changes include:

  • Removal of the replicationfailure suite_test.go file.
  • Addition of multiple new test files under the replication directory for full, incremental, backup-failure, and role-change scenarios.
  • Updates to the CI workflow YAML to replace ginkgo-flags with label-filter configuration.

Reviewed Changes

Copilot reviewed 13 out of 14 changed files in this pull request and generated no comments.

File Description
test/e2e/multik8s/replicationfailure/suite_test.go File removed as part of test reorganization.
test/e2e/multik8s/replication/*.go New/updated test files covering replication, backup scenarios, and role changes.
.github/workflows/e2e-multiple-k8s-clusters.yaml Updated matrix configuration to use label-filter instead of ginkgo-flags for selecting tests.
Files not reviewed (1)
  • test/e2e/Makefile: Language not supported

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.

1 participant