<!-- .github/pull_request_template.md --> ## Description <!-- Provide a clear description of the changes in this PR --> ## DCO Affirmation I affirm that all code in every commit of this pull request conforms to the terms of the Topoteretes Developer Certificate of Origin --------- Co-authored-by: Daniel Molnar <soobrosa@gmail.com> Co-authored-by: Igor Ilic <30923996+dexters1@users.noreply.github.com> Co-authored-by: Igor Ilic <igorilic03@gmail.com>
2.3 KiB
2.3 KiB
Workflow Migration to Test Suites
This document explains how to ensure all test workflows are only run through the central test-suites.yml workflow.
Why Migrate to Test Suites?
- Prevent Duplicate Runs: Avoid running the same tests multiple times
- Sequential Execution: Ensure tests run in the correct order
- Centralized Control: Manage all tests from a single place
- Resource Efficiency: Run tests only when needed
Automated Migration
We've provided a script to automatically convert individual workflows to only run when called by the test-suites.yml file:
# Make the script executable
chmod +x .github/workflows/disable_independent_workflows.sh
# Run the script
.github/workflows/disable_independent_workflows.sh
Manual Migration
For each workflow file that should only run through test-suites.yml:
-
Open the workflow file
-
Find the
on:section, which typically looks like:on: workflow_dispatch: pull_request: types: [labeled, synchronize] -
Replace it with:
on: workflow_call: secrets: inherit: true -
Save the file
Verification
After modifying the workflows, verify that:
- The workflows no longer trigger on pushes or PRs
- The workflows still run correctly when called by test-suites.yml
- No tests are left out of the test-suites.yml orchestrator
Example Conversion
Before:
name: test | chromadb
on:
workflow_dispatch:
pull_request:
types: [labeled, synchronize]
concurrency:
group: ${{ github.workflow }}-${{ github.event.pull_request.number || github.ref }}
cancel-in-progress: false
jobs:
run_chromadb_integration_test:
name: chromadb test
runs-on: ubuntu-22.04
# ...rest of workflow...
After:
name: test | chromadb
on:
workflow_call:
secrets:
inherit: true
jobs:
run_chromadb_integration_test:
name: chromadb test
runs-on: ubuntu-22.04
# ...rest of workflow...
Special Cases
- CI/CD Workflows: Don't modify workflows for CI/CD pipelines like cd.yaml and cd_prd.yaml
- Shared Workflows: Keep reusable_*.yml workflows as they are, since they're already designed to be called by other workflows
- Infrastructure Workflows: Don't modify workflows that handle infrastructure or deployments