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

Internal: Parallel smoke testing #1928

Merged
merged 80 commits into from
Aug 2, 2024
Merged

Conversation

caendesilva
Copy link
Member

@caendesilva caendesilva commented Aug 2, 2024

We've updated our smoke tests workflow to run tests in parallel, improving efficiency while maintaining compatibility with our existing processes. Here are the key changes:

  1. Renamed the workflow to "🔥 Parallel Smoke Tests" to reflect its new parallel nature.
  2. Added a step to prepare separate directories for unit and feature tests.
  3. Introduced a "Run Parallel Smoke Tests" step that:
    • Defines a function run_tests to execute tests for each suite.
    • Runs unit and feature tests in parallel using background processes.
    • Uses sed to prefix each line of output with either [UNIT] or [FEATURE] for clarity, with proper padding for alignment.
    • Generates separate JUnit XML reports for each test suite.
  4. Added a "Merge JUnit XML Reports" step that combines the unit and feature test reports into a single report.xml file, ensuring compatibility with existing ping scripts.
  5. Retained the rest of the workflow, using the combined report.xml for subsequent steps.
  6. Removed the separate CI smoke test feature as this parallel approach is now fast enough.

This parallel approach significantly speeds up the smoke tests while maintaining compatibility with our existing CI processes. We get interleaved, real-time output from both test suites.

graph TD
  A[Start] --> B[Set up environment]
  B --> C[Checkout code]
  C --> D[Validate composer files]
  D --> E[Cache Composer packages]
  E --> F[Install dependencies]
  F --> G[Prepare test directories]
  G --> H[Run Unit Tests]
  G --> I[Run Feature Tests]
  H --> J[Generate Unit Test Report]
  I --> K[Generate Feature Test Report]
  J --> L[Merge JUnit XML Reports]
  K --> L
  L --> N[Ping statistics server]
  N --> O[End]
  style H fill:#f9f,stroke:#333,stroke-width:2px,color:#333
  style I fill:#f9f,stroke:#333,stroke-width:2px,color:#333
  style J fill:#ccf,stroke:#333,stroke-width:2px,color:#333
  style K fill:#ccf,stroke:#333,stroke-width:2px,color:#333
  style L fill:#fcc,stroke:#333,stroke-width:2px,color:#333
Loading

@github-actions github-actions bot added the internal This pull request does not affect package code label Aug 2, 2024
@caendesilva caendesilva force-pushed the parallel-coverage-testing branch from 94200cc to 2337a94 Compare August 2, 2024 09:19
@caendesilva
Copy link
Member Author

caendesilva commented Aug 2, 2024

Baseline test execution time 2337a94

  • 1m 2s for test execution time
  • 1m 22s for test succeeded time

Copy link

codecov bot commented Aug 2, 2024

Codecov Report

All modified and coverable lines are covered by tests ✅

Project coverage is 100.00%. Comparing base (305a6fc) to head (766b7e6).
Report is 4 commits behind head on master.

Additional details and impacted files
@@             Coverage Diff             @@
##              master     #1928   +/-   ##
===========================================
  Coverage     100.00%   100.00%           
  Complexity      1766      1766           
===========================================
  Files            182       182           
  Lines           4707      4707           
===========================================
  Hits            4707      4707           

☔ View full report in Codecov by Sentry.
📢 Have feedback on the report? Share it here.

@caendesilva caendesilva force-pushed the parallel-coverage-testing branch 2 times, most recently from 0363721 to f5be177 Compare August 2, 2024 09:49
@caendesilva
Copy link
Member Author

caendesilva commented Aug 2, 2024

Merging coverage adds a lot of complexity, so pivoting to do smoke tests in parallel as that's where the biggest pain point is anyway, and we don't need to assemble so much data.

Baseline execution time (spot test)
26s for test execution time
34s for test succeeded time

New execution time (spot test)
20s for test execution time
31s for test succeeded time

caendesilva added a commit that referenced this pull request Aug 2, 2024
@caendesilva caendesilva changed the title Internal: Parallel coverage testing Internal: Parallel smoke testing Aug 2, 2024
@caendesilva caendesilva marked this pull request as ready for review August 2, 2024 13:41
@caendesilva caendesilva force-pushed the parallel-coverage-testing branch from 766b7e6 to b082f4c Compare August 2, 2024 14:15
@caendesilva caendesilva force-pushed the parallel-coverage-testing branch from 8542971 to a180d59 Compare August 2, 2024 15:25
@caendesilva caendesilva enabled auto-merge August 2, 2024 15:26
@caendesilva caendesilva disabled auto-merge August 2, 2024 15:27
@caendesilva caendesilva merged commit c6d0ca0 into master Aug 2, 2024
12 checks passed
@caendesilva caendesilva deleted the parallel-coverage-testing branch August 2, 2024 15:27
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
internal This pull request does not affect package code
Projects
None yet
Development

Successfully merging this pull request may close these issues.

1 participant