Skip to content

Commit ac4b9cd

Browse files
committed
clean up duplicates
1 parent ebbc8d8 commit ac4b9cd

File tree

3 files changed

+31
-106
lines changed

3 files changed

+31
-106
lines changed

.github/actions/deploy-to-control-plane/action.yml

+5-69
Original file line numberDiff line numberDiff line change
@@ -32,80 +32,16 @@ outputs:
3232
runs:
3333
using: "composite"
3434
steps:
35-
- name: Validate Required Secrets
36-
shell: bash
37-
run: |
38-
missing_secrets=()
39-
for secret in "CPLN_TOKEN" "CPLN_ORG"; do
40-
if [ -z "${!secret}" ]; then
41-
missing_secrets+=("$secret")
42-
fi
43-
done
44-
45-
if [ ${#missing_secrets[@]} -ne 0 ]; then
46-
echo "Required secrets are not set: ${missing_secrets[*]}"
47-
exit 1
48-
fi
49-
50-
- name: Setup Environment
51-
uses: ./.github/actions/setup-environment
52-
53-
- name: Get Commit SHA
54-
id: get_sha
55-
shell: bash
56-
run: ${{ github.action_path }}/scripts/get-commit-sha.sh
57-
env:
58-
GITHUB_TOKEN: ${{ inputs.github_token }}
59-
PR_NUMBER: ${{ inputs.pr_number }}
60-
6135
- name: Deploy to Control Plane
6236
id: deploy
6337
shell: bash
6438
env:
39+
APP_NAME: ${{ inputs.app_name }}
40+
CPLN_ORG: ${{ inputs.org }}
6541
CPLN_TOKEN: ${{ inputs.cpln_token }}
66-
PR_NUMBER: ${{ inputs.pr_number }}
42+
WAIT_TIMEOUT: ${{ inputs.wait_timeout }}
6743
run: |
68-
echo "🚀 Deploying app for PR #${PR_NUMBER}..."
69-
70-
# Create temp file for output
71-
TEMP_OUTPUT=$(mktemp)
72-
trap 'rm -f "${TEMP_OUTPUT}"' EXIT
73-
74-
# Deploy the application and show output in real-time while capturing it
75-
if ! cpflow deploy-image -a "${{ inputs.app_name }}" --run-release-phase --org "${{ inputs.org }}" 2>&1 | tee "${TEMP_OUTPUT}"; then
76-
echo "❌ Deployment failed for PR #${PR_NUMBER}"
77-
echo "Error output:"
78-
cat "${TEMP_OUTPUT}"
79-
exit 1
80-
fi
81-
82-
# Extract app URL from captured output
83-
REVIEW_APP_URL=$(grep -oP 'https://rails-[^[:space:]]*\.cpln\.app(?=\s|$)' "${TEMP_OUTPUT}" | head -n1)
84-
if [ -z "${REVIEW_APP_URL}" ]; then
85-
echo "❌ Failed to get app URL from deployment output"
86-
echo "Deployment output:"
87-
cat "${TEMP_OUTPUT}"
88-
exit 1
89-
fi
90-
91-
# Wait for all workloads to be ready
92-
WAIT_TIMEOUT=${WAIT_TIMEOUT:-${{ inputs.wait_timeout }}}
93-
echo "⏳ Waiting for all workloads to be ready (timeout: ${WAIT_TIMEOUT}s)..."
94-
95-
# Use timeout command with ps:wait and show output in real-time
96-
if ! timeout "${WAIT_TIMEOUT}" bash -c "cpflow ps:wait -a \"${{ inputs.app_name }}\"" 2>&1 | tee -a "${TEMP_OUTPUT}"; then
97-
TIMEOUT_EXIT=$?
98-
if [ ${TIMEOUT_EXIT} -eq 124 ]; then
99-
echo "❌ Timed out waiting for workloads after ${WAIT_TIMEOUT} seconds"
100-
else
101-
echo "❌ Workloads did not become ready for PR #${PR_NUMBER} (exit code: ${TIMEOUT_EXIT})"
102-
fi
103-
echo "Full output:"
104-
cat "${TEMP_OUTPUT}"
44+
# Run the deployment script
45+
if ! ${{ github.action_path }}/scripts/deploy.sh; then
10546
exit 1
10647
fi
107-
108-
echo "✅ Deployment successful for PR #${PR_NUMBER}"
109-
echo "🌐 App URL: ${REVIEW_APP_URL}"
110-
echo "review_app_url=${REVIEW_APP_URL}" >> $GITHUB_OUTPUT
111-
echo "REVIEW_APP_URL=${REVIEW_APP_URL}" >> $GITHUB_ENV

.github/actions/deploy-to-control-plane/scripts/get-commit-sha.sh

-34
This file was deleted.

.github/workflows/deploy-to-control-plane.yml

+26-3
Original file line numberDiff line numberDiff line change
@@ -24,7 +24,7 @@ concurrency:
2424
cancel-in-progress: true
2525

2626
env:
27-
APP_NAME: qa-react-webpack-rails-tutorial-pr-${{ github.event.pull_request.number || github.event.issue.number || github.event.inputs.pr_number }}
27+
APP_NAME: ${{ vars.REVIEW_APP_PREFIX }}-${{ github.event.pull_request.number || github.event.issue.number || github.event.inputs.pr_number }}
2828
CPLN_TOKEN: ${{ secrets.CPLN_TOKEN_STAGING }}
2929
CPLN_ORG: ${{ vars.CPLN_ORG_STAGING }}
3030
PR_NUMBER: ${{ github.event.pull_request.number || github.event.issue.number || github.event.inputs.pr_number }}
@@ -55,13 +55,36 @@ jobs:
5555
ref: ${{ github.event_name == 'pull_request' && github.event.pull_request.head.sha || github.ref }}
5656

5757
# Basic checkout for other events (workflow_dispatch, issue_comment)
58-
# We'll do proper checkout after getting PR info
5958
- name: Initial checkout
6059
if: github.event_name == 'workflow_dispatch' || github.event_name == 'issue_comment'
6160
uses: actions/checkout@v4
6261
with:
6362
fetch-depth: 0
6463

64+
- name: Validate Required Secrets and Variables
65+
shell: bash
66+
run: |
67+
missing=()
68+
69+
# Check secrets
70+
if [ -z "${{ secrets.CPLN_TOKEN_STAGING }}" ]; then
71+
missing+=("Secret: CPLN_TOKEN_STAGING")
72+
fi
73+
74+
# Check variables
75+
if [ -z "${{ vars.CPLN_ORG_STAGING }}" ]; then
76+
missing+=("Variable: CPLN_ORG_STAGING")
77+
fi
78+
79+
if [ -z "${{ vars.REVIEW_APP_PREFIX }}" ]; then
80+
missing+=("Variable: REVIEW_APP_PREFIX")
81+
fi
82+
83+
if [ ${#missing[@]} -ne 0 ]; then
84+
echo "Required secrets/variables are not set: ${missing[*]}"
85+
exit 1
86+
fi
87+
6588
- name: Get PR HEAD Ref
6689
id: getRef
6790
env:
@@ -91,7 +114,7 @@ jobs:
91114
92115
# Set environment variables
93116
echo "PR_NUMBER=$PR_NUMBER" >> $GITHUB_ENV
94-
echo "APP_NAME=qa-react-webpack-rails-tutorial-pr-$PR_NUMBER" >> $GITHUB_ENV
117+
echo "APP_NAME=${{ vars.REVIEW_APP_PREFIX }}-$PR_NUMBER" >> $GITHUB_ENV
95118
96119
# Get PR data using GitHub CLI
97120
PR_DATA=$(gh pr view $PR_NUMBER --repo shakacode/react-webpack-rails-tutorial --json headRefName,headRefOid)

0 commit comments

Comments
 (0)