Internal: Parallel smoke testing #12349
Workflow file for this run
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
name: 🔥 Parallel Smoke Tests | |
on: | |
pull_request: | |
jobs: | |
run-smoke-tests: | |
runs-on: ubuntu-latest | |
steps: | |
- name: Checkout code | |
uses: actions/checkout@v4 | |
with: | |
path: src | |
- name: Validate composer.json and composer.lock | |
run: | | |
cd src && composer validate --strict --no-check-all | |
- name: Cache Composer packages | |
id: composer-cache | |
uses: actions/cache@v4 | |
with: | |
path: src/vendor | |
key: ${{ runner.os }}-php-${{ hashFiles('**/composer.lock') }} | |
restore-keys: | | |
${{ runner.os }}-php- | |
- name: Install Composer Dependencies | |
run: | | |
cd src && composer install --no-ansi --no-interaction --no-scripts --no-progress --prefer-dist | |
- name: Prepare test directories | |
run: | | |
echo "Starting directory preparation" | |
start_time=$(date +%s%N) | |
# Create a single copy of the source | |
cp -R src test_base | |
# Create symbolic links for other test directories | |
for suite in unit feature_hyde feature_framework publications realtime_compiler; do | |
ln -s test_base ${suite}_tests | |
done | |
# Move .git directory | |
mv src/.git . | |
end_time=$(date +%s%N) | |
duration=$(( (end_time - start_time) / 1000000 )) | |
echo "Directory preparation completed in $duration milliseconds" | |
- name: Execute Tests in Parallel | |
run: | | |
mkdir -p test_results | |
mkdir -p test_outputs | |
# Function to run tests | |
run_tests() { | |
local suite=$1 | |
local testsuite=$2 | |
echo "${suite^} tests started" | |
cd ${suite}_tests | |
if vendor/bin/pest --colors=always --log-junit="../test_results/${suite}_junit.xml" --testsuite="$testsuite" > "../test_outputs/${suite}.log" 2>&1; then | |
echo "${suite^} tests completed successfully" | |
else | |
echo "${suite^} tests failed" | |
return 1 | |
fi | |
} | |
# Run tests in parallel and capture exit codes | |
run_tests unit UnitFramework & pid1=$! | |
run_tests feature_hyde FeatureHyde & pid2=$! | |
run_tests feature_framework FeatureFramework & pid3=$! | |
run_tests publications Publications & pid4=$! | |
run_tests realtime_compiler "Realtime Compiler" & pid5=$! | |
# Wait for all background jobs to finish and capture exit codes | |
wait $pid1 || echo "Unit tests failed" >> test_failures | |
wait $pid2 || echo "Feature Hyde tests failed" >> test_failures | |
wait $pid3 || echo "Feature Framework tests failed" >> test_failures | |
wait $pid4 || echo "Publications tests failed" >> test_failures | |
wait $pid5 || echo "Realtime Compiler tests failed" >> test_failures | |
# Check if any tests failed | |
if [ -f test_failures ]; then | |
echo "The following test suites failed:" | |
cat test_failures | |
exit 1 | |
fi | |
- name: Display Unit Tests Output | |
if: always() | |
run: cat test_outputs/unit.log | |
- name: Display Feature Hyde Tests Output | |
if: always() | |
run: cat test_outputs/feature_hyde.log | |
- name: Display Feature Framework Tests Output | |
if: always() | |
run: cat test_outputs/feature_framework.log | |
- name: Display Publications Tests Output | |
if: always() | |
run: cat test_outputs/publications.log | |
- name: Display Realtime Compiler Tests Output | |
if: always() | |
run: cat test_outputs/realtime_compiler.log | |
- name: Merge JUnit XML Reports | |
if: always() | |
run: | | |
php -r ' | |
$files = glob("test_results/*_junit.xml"); | |
$totalTests = $totalAssertions = $totalTime = 0; | |
foreach ($files as $file) { | |
$xml = simplexml_load_file($file); | |
$totalTests += (int)$xml->testsuite["tests"]; | |
$totalAssertions += (int)$xml->testsuite["assertions"]; | |
$totalTime += (float)$xml->testsuite["time"]; | |
} | |
$output = sprintf( | |
"<?xml version=\"1.0\" encoding=\"UTF-8\"?>\n<testsuites>\n <testsuite name=\"%s\" tests=\"%d\" assertions=\"%d\" errors=\"0\" failures=\"0\" skipped=\"0\" time=\"%.6f\">\n </testsuite>\n</testsuites>", | |
"H:\\monorepo\\phpunit.xml.dist", | |
$totalTests, | |
$totalAssertions, | |
$totalTime | |
); | |
file_put_contents("report.xml", $output); | |
' | |
- name: Ping statistics server with test results | |
if: always() | |
run: | | |
curl https://raw.githubusercontent.com/hydephp/develop/6e9d17f31879f4ccda13a3fec4029c9663bccec0/monorepo/scripts/ping-openanalytics-testrunner.php -o ping.php | |
php ping.php "Monorepo Smoke Tests" ${{ secrets.OPENANALYTICS_TOKEN }} ${{ github.ref_name }} |