ci: Add comprehensive CI/CD workflow
- Added GitHub Actions workflow for testing and deployment - Implemented multi-stage deployment with validation - Added visual regression testing to CI process - Integrated all resilience scripts into automated workflow - Added staging and production deployment pipelines 🤖 Generated with [Claude Code](https://claude.ai/code) Co-Authored-By: Claude <noreply@anthropic.com>
This commit is contained in:
parent
b3b0901cd6
commit
cec59b1f6e
1 changed files with 297 additions and 0 deletions
297
wordpress-dev/.github/workflows/test-and-deploy.yml
vendored
Normal file
297
wordpress-dev/.github/workflows/test-and-deploy.yml
vendored
Normal file
|
|
@ -0,0 +1,297 @@
|
|||
name: Test and Deploy
|
||||
|
||||
on:
|
||||
push:
|
||||
branches: [ main, cloudways-dev ]
|
||||
pull_request:
|
||||
branches: [ main, cloudways-dev ]
|
||||
workflow_dispatch:
|
||||
inputs:
|
||||
deploy_type:
|
||||
description: 'Deployment Type'
|
||||
required: true
|
||||
default: 'staging'
|
||||
type: choice
|
||||
options:
|
||||
- staging
|
||||
- canary
|
||||
- production
|
||||
|
||||
jobs:
|
||||
health-check:
|
||||
name: System Health Check
|
||||
runs-on: ubuntu-latest
|
||||
|
||||
steps:
|
||||
- name: Checkout code
|
||||
uses: actions/checkout@v3
|
||||
|
||||
- name: Setup Node.js
|
||||
uses: actions/setup-node@v3
|
||||
with:
|
||||
node-version: '18'
|
||||
cache: 'npm'
|
||||
cache-dependency-path: wordpress-dev/package-lock.json
|
||||
|
||||
- name: Install dependencies
|
||||
run: |
|
||||
cd wordpress-dev
|
||||
npm ci
|
||||
|
||||
- name: Install Playwright browsers
|
||||
run: |
|
||||
cd wordpress-dev
|
||||
npx playwright install --with-deps
|
||||
|
||||
- name: Run health check
|
||||
run: |
|
||||
cd wordpress-dev
|
||||
bash bin/health-check.sh --ci
|
||||
|
||||
- name: Verify selectors
|
||||
run: |
|
||||
cd wordpress-dev
|
||||
bash bin/verify-selectors.sh --ci
|
||||
|
||||
test:
|
||||
name: Run Tests
|
||||
needs: health-check
|
||||
runs-on: ubuntu-latest
|
||||
|
||||
steps:
|
||||
- name: Checkout code
|
||||
uses: actions/checkout@v3
|
||||
|
||||
- name: Setup Node.js
|
||||
uses: actions/setup-node@v3
|
||||
with:
|
||||
node-version: '18'
|
||||
cache: 'npm'
|
||||
cache-dependency-path: wordpress-dev/package-lock.json
|
||||
|
||||
- name: Install dependencies
|
||||
run: |
|
||||
cd wordpress-dev
|
||||
npm ci
|
||||
|
||||
- name: Install Playwright browsers
|
||||
run: |
|
||||
cd wordpress-dev
|
||||
npx playwright install --with-deps
|
||||
|
||||
- name: Create screenshots directory
|
||||
run: mkdir -p wordpress-dev/screenshots
|
||||
|
||||
- name: Run E2E tests
|
||||
run: |
|
||||
cd wordpress-dev
|
||||
npx playwright test --config=playwright.config.ts
|
||||
|
||||
- name: Analyze test results
|
||||
if: always()
|
||||
run: |
|
||||
cd wordpress-dev
|
||||
bash bin/test-monitor.sh --store --notify --threshold=80
|
||||
|
||||
- name: Upload test results
|
||||
if: always()
|
||||
uses: actions/upload-artifact@v3
|
||||
with:
|
||||
name: test-results
|
||||
path: |
|
||||
wordpress-dev/test-results
|
||||
wordpress-dev/screenshots
|
||||
wordpress-dev/logs
|
||||
|
||||
visual-regression:
|
||||
name: Visual Regression Test
|
||||
needs: test
|
||||
runs-on: ubuntu-latest
|
||||
if: github.event_name == 'pull_request' || github.event.inputs.deploy_type != ''
|
||||
|
||||
steps:
|
||||
- name: Checkout code
|
||||
uses: actions/checkout@v3
|
||||
|
||||
- name: Setup Node.js
|
||||
uses: actions/setup-node@v3
|
||||
with:
|
||||
node-version: '18'
|
||||
cache: 'npm'
|
||||
cache-dependency-path: wordpress-dev/package-lock.json
|
||||
|
||||
- name: Install dependencies
|
||||
run: |
|
||||
cd wordpress-dev
|
||||
npm ci
|
||||
|
||||
- name: Install Playwright browsers
|
||||
run: |
|
||||
cd wordpress-dev
|
||||
npx playwright install --with-deps
|
||||
|
||||
- name: Install ImageMagick
|
||||
run: |
|
||||
sudo apt-get update
|
||||
sudo apt-get install -y imagemagick
|
||||
|
||||
- name: Download baseline screenshots
|
||||
uses: actions/download-artifact@v3
|
||||
with:
|
||||
name: visual-regression-baseline
|
||||
path: wordpress-dev/tests/e2e/visual-regression/baseline
|
||||
continue-on-error: true
|
||||
|
||||
- name: Capture current screenshots
|
||||
run: |
|
||||
cd wordpress-dev
|
||||
bash bin/visual-regression.sh capture
|
||||
|
||||
- name: Establish baseline if not exists
|
||||
run: |
|
||||
cd wordpress-dev
|
||||
if [ ! -d "tests/e2e/visual-regression/baseline" ] || [ -z "$(ls -A tests/e2e/visual-regression/baseline)" ]; then
|
||||
cp -r tests/e2e/visual-regression/current/* tests/e2e/visual-regression/baseline/
|
||||
echo "Created baseline from current screenshots"
|
||||
fi
|
||||
|
||||
- name: Compare screenshots
|
||||
run: |
|
||||
cd wordpress-dev
|
||||
bash bin/visual-regression.sh compare --threshold=5
|
||||
|
||||
- name: Generate report
|
||||
if: always()
|
||||
run: |
|
||||
cd wordpress-dev
|
||||
bash bin/visual-regression.sh report
|
||||
|
||||
- name: Upload visual regression results
|
||||
if: always()
|
||||
uses: actions/upload-artifact@v3
|
||||
with:
|
||||
name: visual-regression-results
|
||||
path: wordpress-dev/tests/e2e/visual-regression
|
||||
|
||||
- name: Save current screenshots as baseline
|
||||
if: github.event_name == 'push' && github.ref == 'refs/heads/main'
|
||||
uses: actions/upload-artifact@v3
|
||||
with:
|
||||
name: visual-regression-baseline
|
||||
path: wordpress-dev/tests/e2e/visual-regression/current
|
||||
|
||||
optimize:
|
||||
name: Optimize Tests
|
||||
needs: test
|
||||
runs-on: ubuntu-latest
|
||||
if: github.event_name == 'push' && github.ref == 'refs/heads/main'
|
||||
|
||||
steps:
|
||||
- name: Checkout code
|
||||
uses: actions/checkout@v3
|
||||
|
||||
- name: Setup Node.js
|
||||
uses: actions/setup-node@v3
|
||||
with:
|
||||
node-version: '18'
|
||||
|
||||
- name: Analyze test performance
|
||||
run: |
|
||||
cd wordpress-dev
|
||||
bash bin/optimize-tests.sh analyze
|
||||
|
||||
- name: Upload optimization analysis
|
||||
uses: actions/upload-artifact@v3
|
||||
with:
|
||||
name: test-optimization
|
||||
path: wordpress-dev/tests/e2e/analysis
|
||||
|
||||
deploy-staging:
|
||||
name: Deploy to Staging
|
||||
needs: [test, visual-regression]
|
||||
runs-on: ubuntu-latest
|
||||
if: github.event_name == 'push' && github.ref == 'refs/heads/cloudways-dev'
|
||||
|
||||
steps:
|
||||
- name: Checkout code
|
||||
uses: actions/checkout@v3
|
||||
|
||||
- name: Pre-deployment validation
|
||||
run: |
|
||||
cd wordpress-dev
|
||||
bash bin/pre-deploy-validation.sh --ci
|
||||
|
||||
- name: Deploy to staging
|
||||
run: |
|
||||
cd wordpress-dev
|
||||
bash bin/deploy-plugin.sh --staging
|
||||
|
||||
- name: Verify deployment
|
||||
run: |
|
||||
cd wordpress-dev
|
||||
bash bin/verify-staging.sh
|
||||
|
||||
deploy-production:
|
||||
name: Deploy to Production
|
||||
needs: [test, visual-regression]
|
||||
runs-on: ubuntu-latest
|
||||
if: github.event.inputs.deploy_type == 'production'
|
||||
|
||||
environment:
|
||||
name: production
|
||||
url: https://upskill.measurequick.com
|
||||
|
||||
steps:
|
||||
- name: Checkout code
|
||||
uses: actions/checkout@v3
|
||||
|
||||
- name: Pre-deployment validation
|
||||
run: |
|
||||
cd wordpress-dev
|
||||
bash bin/pre-deploy-validation.sh --ci
|
||||
|
||||
- name: Deploy canary
|
||||
run: |
|
||||
cd wordpress-dev
|
||||
bash bin/canary-deploy.sh --percentage=10 --wait=5
|
||||
|
||||
- name: Deploy to production
|
||||
run: |
|
||||
cd wordpress-dev
|
||||
bash bin/deploy.sh --config deploy-config.sh
|
||||
|
||||
- name: Run smoke tests
|
||||
run: |
|
||||
cd wordpress-dev
|
||||
npx playwright test tests/e2e/smoke-tests.spec.ts --config=playwright.config.ts
|
||||
|
||||
- name: Verify deployment
|
||||
run: |
|
||||
cd wordpress-dev
|
||||
bash bin/verify-production.sh
|
||||
|
||||
notify:
|
||||
name: Send Notifications
|
||||
needs: [deploy-staging, deploy-production]
|
||||
runs-on: ubuntu-latest
|
||||
if: always()
|
||||
|
||||
steps:
|
||||
- name: Check deployment status
|
||||
id: check
|
||||
run: |
|
||||
if [[ "${{ needs.deploy-staging.result }}" == "success" || "${{ needs.deploy-production.result }}" == "success" ]]; then
|
||||
echo "status=success" >> $GITHUB_OUTPUT
|
||||
else
|
||||
echo "status=failure" >> $GITHUB_OUTPUT
|
||||
fi
|
||||
|
||||
- name: Send success notification
|
||||
if: steps.check.outputs.status == 'success'
|
||||
run: |
|
||||
echo "Deployment successful! Notification would be sent here."
|
||||
|
||||
- name: Send failure notification
|
||||
if: steps.check.outputs.status != 'success'
|
||||
run: |
|
||||
echo "Deployment failed! Notification would be sent here."
|
||||
Loading…
Reference in a new issue