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