Add renovate tests #35
44
.gitea/workflows/test.yaml
Normal file
44
.gitea/workflows/test.yaml
Normal file
@@ -0,0 +1,44 @@
|
|||||||
|
name: Test Renovate Config
|
||||||
|
on:
|
||||||
|
push:
|
||||||
|
branches:
|
||||||
|
- main
|
||||||
|
pull_request:
|
||||||
|
branches:
|
||||||
|
- main
|
||||||
|
|
||||||
|
concurrency:
|
||||||
|
group: renovate-test-lock
|
||||||
|
cancel-in-progress: false
|
||||||
|
|
||||||
|
jobs:
|
||||||
|
test-renovate:
|
||||||
|
runs-on: ubuntu-latest
|
||||||
|
container: ghcr.io/renovatebot/renovate:42.8.1
|
||||||
|
steps:
|
||||||
|
- name: Checkout
|
||||||
|
uses: actions/checkout@v5.0.0
|
||||||
|
|
||||||
|
- name: Run Renovate Test Script
|
||||||
|
run: bash scripts/test-renovate.sh
|
||||||
|
env:
|
||||||
|
RENOVATE_CONFIG_FILE: "/workspace/kovagoadi.hu/Renovate/renovate-config.js"
|
||||||
|
LOG_LEVEL: "debug"
|
||||||
|
RENOVATE_TOKEN: ${{ secrets.RENOVATE_TEST_TOKEN }}
|
||||||
|
GITHUB_COM_TOKEN: ${{ secrets.RENOVATE_GITHUB_TOKEN }}
|
||||||
|
|
||||||
|
e2e-renovate:
|
||||||
|
runs-on: ubuntu-latest
|
||||||
|
needs: test-renovate
|
||||||
|
container: ghcr.io/renovatebot/renovate:42.8.1
|
||||||
|
steps:
|
||||||
|
- name: Checkout
|
||||||
|
uses: actions/checkout@v5.0.0
|
||||||
|
|
||||||
|
- name: Run Renovate E2E Script
|
||||||
|
run: bash scripts/e2e-renovate.sh
|
||||||
|
env:
|
||||||
|
RENOVATE_CONFIG_FILE: "/workspace/kovagoadi.hu/Renovate/renovate-config.js"
|
||||||
|
LOG_LEVEL: "debug"
|
||||||
|
RENOVATE_TOKEN: ${{ secrets.RENOVATE_TEST_TOKEN }}
|
||||||
|
GITHUB_COM_TOKEN: ${{ secrets.RENOVATE_GITHUB_TOKEN }}
|
||||||
210
scripts/e2e-renovate.sh
Executable file
210
scripts/e2e-renovate.sh
Executable file
@@ -0,0 +1,210 @@
|
|||||||
|
#!/bin/bash
|
||||||
|
set -e
|
||||||
|
|
||||||
|
echo "Validating Renovate configuration..."
|
||||||
|
renovate-config-validator
|
||||||
|
|
||||||
|
echo "Running Renovate E2E (no dry-run)..."
|
||||||
|
# Capture output but also stream it to stdout for debugging
|
||||||
|
set +e
|
||||||
|
renovate > renovate-e2e-output.log 2>&1
|
||||||
|
RENOVATE_EXIT_CODE=$?
|
||||||
|
set -e
|
||||||
|
|
||||||
|
cat renovate-e2e-output.log
|
||||||
|
|
||||||
|
if [ $RENOVATE_EXIT_CODE -ne 0 ]; then
|
||||||
|
echo "Error: Renovate command failed with exit code $RENOVATE_EXIT_CODE"
|
||||||
|
exit 1
|
||||||
|
fi
|
||||||
|
|
||||||
|
# Assertions
|
||||||
|
echo "Checking for successful run..."
|
||||||
|
if ! grep -q "Repository finished" renovate-e2e-output.log; then
|
||||||
|
echo "Error: Renovate run did not finish successfully."
|
||||||
|
exit 1
|
||||||
|
fi
|
||||||
|
|
||||||
|
echo "Checking for errors..."
|
||||||
|
if grep -q "ERROR" renovate-e2e-output.log; then
|
||||||
|
echo "Error: Renovate log contains errors."
|
||||||
|
exit 1
|
||||||
|
fi
|
||||||
|
|
||||||
|
echo "E2E Test passed!"
|
||||||
|
rm renovate-e2e-output.log
|
||||||
|
|
||||||
|
# API Verification and Cleanup
|
||||||
|
GITEA_API_URL="https://gitea.kovagoadi.hu/api/v1"
|
||||||
|
REPO_OWNER="renovate-test"
|
||||||
|
REPO_NAME="test"
|
||||||
|
|
||||||
|
# Function to clean up PRs and reset repo
|
||||||
|
cleanup() {
|
||||||
|
echo "Cleaning up..."
|
||||||
|
|
||||||
|
# 1. Delete all Open PRs
|
||||||
|
echo "Deleting Open PRs..."
|
||||||
|
PRS=$(curl -s -H "Authorization: token $RENOVATE_TOKEN" "$GITEA_API_URL/repos/$REPO_OWNER/$REPO_NAME/pulls?state=open")
|
||||||
|
PR_INDEXES=$(echo "$PRS" | jq -r '.[].number')
|
||||||
|
for INDEX in $PR_INDEXES; do
|
||||||
|
if [ "$INDEX" != "null" ]; then
|
||||||
|
echo "Deleting PR #$INDEX..."
|
||||||
|
curl -s -X DELETE -H "Authorization: token $RENOVATE_TOKEN" "$GITEA_API_URL/repos/$REPO_OWNER/$REPO_NAME/issues/$INDEX"
|
||||||
|
fi
|
||||||
|
done
|
||||||
|
|
||||||
|
# 2. Delete "Configure Renovate" PR (Closed/Merged)
|
||||||
|
echo "Deleting 'Configure Renovate' PR..."
|
||||||
|
# Fetch closed PRs to find the onboarding one
|
||||||
|
CLOSED_PRS=$(curl -s -H "Authorization: token $RENOVATE_TOKEN" "$GITEA_API_URL/repos/$REPO_OWNER/$REPO_NAME/pulls?state=closed")
|
||||||
|
ONBOARDING_PR_INDEX=$(echo "$CLOSED_PRS" | jq -r '.[] | select(.title | contains("Configure Renovate")) | .number')
|
||||||
|
if [ -n "$ONBOARDING_PR_INDEX" ] && [ "$ONBOARDING_PR_INDEX" != "null" ]; then
|
||||||
|
echo "Deleting Onboarding PR #$ONBOARDING_PR_INDEX..."
|
||||||
|
curl -s -X DELETE -H "Authorization: token $RENOVATE_TOKEN" "$GITEA_API_URL/repos/$REPO_OWNER/$REPO_NAME/issues/$ONBOARDING_PR_INDEX"
|
||||||
|
fi
|
||||||
|
|
||||||
|
# 3. Delete "Dependency Dashboard" Issue
|
||||||
|
echo "Deleting 'Dependency Dashboard' Issue..."
|
||||||
|
ISSUES=$(curl -s -H "Authorization: token $RENOVATE_TOKEN" "$GITEA_API_URL/repos/$REPO_OWNER/$REPO_NAME/issues?state=open")
|
||||||
|
DASHBOARD_INDEX=$(echo "$ISSUES" | jq -r '.[] | select(.title | contains("Dependency Dashboard")) | .number')
|
||||||
|
if [ -n "$DASHBOARD_INDEX" ] && [ "$DASHBOARD_INDEX" != "null" ]; then
|
||||||
|
echo "Deleting Dashboard Issue #$DASHBOARD_INDEX..."
|
||||||
|
curl -s -X DELETE -H "Authorization: token $RENOVATE_TOKEN" "$GITEA_API_URL/repos/$REPO_OWNER/$REPO_NAME/issues/$DASHBOARD_INDEX"
|
||||||
|
fi
|
||||||
|
|
||||||
|
# 4. Delete Renovate Branches
|
||||||
|
echo "Deleting Renovate Branches..."
|
||||||
|
BRANCHES=$(curl -s -H "Authorization: token $RENOVATE_TOKEN" "$GITEA_API_URL/repos/$REPO_OWNER/$REPO_NAME/branches")
|
||||||
|
RENOVATE_BRANCHES=$(echo "$BRANCHES" | jq -r '.[].name | select(startswith("renovate/"))')
|
||||||
|
for BRANCH in $RENOVATE_BRANCHES; do
|
||||||
|
if [ -n "$BRANCH" ]; then
|
||||||
|
echo "Deleting branch $BRANCH..."
|
||||||
|
# URL encode branch name (slash needs to be %2F, but curl might handle it or we need to be careful)
|
||||||
|
# Gitea API: DELETE /repos/{owner}/{repo}/branches/{branch}
|
||||||
|
# Simple bash URL encoding for slash
|
||||||
|
ENCODED_BRANCH=${BRANCH//\//%2F}
|
||||||
|
curl -s -X DELETE -H "Authorization: token $RENOVATE_TOKEN" "$GITEA_API_URL/repos/$REPO_OWNER/$REPO_NAME/branches/$ENCODED_BRANCH"
|
||||||
|
fi
|
||||||
|
done
|
||||||
|
|
||||||
|
# 5. Delete renovate.json from main branch to reset state (if exists)
|
||||||
|
FILE_INFO=$(curl -s -H "Authorization: token $RENOVATE_TOKEN" "$GITEA_API_URL/repos/$REPO_OWNER/$REPO_NAME/contents/renovate.json?ref=main")
|
||||||
|
FILE_SHA=$(echo "$FILE_INFO" | jq -r '.sha')
|
||||||
|
|
||||||
|
if [ "$FILE_SHA" != "null" ] && [ -n "$FILE_SHA" ]; then
|
||||||
|
echo "Deleting renovate.json to reset repository state..."
|
||||||
|
curl -s -X DELETE -H "Authorization: token $RENOVATE_TOKEN" \
|
||||||
|
-H "Content-Type: application/json" \
|
||||||
|
-d "{\"message\": \"Cleanup: Delete renovate.json\", \"sha\": \"$FILE_SHA\", \"branch\": \"main\"}" \
|
||||||
|
"$GITEA_API_URL/repos/$REPO_OWNER/$REPO_NAME/contents/renovate.json"
|
||||||
|
fi
|
||||||
|
}
|
||||||
|
|
||||||
|
# Register cleanup to run on exit
|
||||||
|
trap cleanup EXIT
|
||||||
|
|
||||||
|
# --- Step 1: Initial Run (Onboarding) ---
|
||||||
|
echo "Running Renovate E2E (Run 1: Onboarding)..."
|
||||||
|
set +e
|
||||||
|
renovate --pr-hourly-limit=0 > renovate-e2e-output.log 2>&1
|
||||||
|
RENOVATE_EXIT_CODE=$?
|
||||||
|
set -e
|
||||||
|
cat renovate-e2e-output.log
|
||||||
|
|
||||||
|
if [ $RENOVATE_EXIT_CODE -ne 0 ]; then
|
||||||
|
echo "Error: Renovate command failed."
|
||||||
|
exit 1
|
||||||
|
fi
|
||||||
|
|
||||||
|
# Check for Onboarding PR
|
||||||
|
PRS=$(curl -s -H "Authorization: token $RENOVATE_TOKEN" "$GITEA_API_URL/repos/$REPO_OWNER/$REPO_NAME/pulls?state=open")
|
||||||
|
ONBOARDING_PR_NUM=$(echo "$PRS" | jq -r '.[] | select(.title | contains("Configure Renovate")) | .number')
|
||||||
|
|
||||||
|
if [ -n "$ONBOARDING_PR_NUM" ] && [ "$ONBOARDING_PR_NUM" != "null" ]; then
|
||||||
|
echo "Onboarding PR found (#$ONBOARDING_PR_NUM). Merging it to enable updates..."
|
||||||
|
|
||||||
|
# Merge Onboarding PR
|
||||||
|
MERGE_RESP=$(curl -s -X POST -H "Authorization: token $RENOVATE_TOKEN" \
|
||||||
|
-H "Content-Type: application/json" \
|
||||||
|
-d "{\"Do\": \"merge\"}" \
|
||||||
|
"$GITEA_API_URL/repos/$REPO_OWNER/$REPO_NAME/pulls/$ONBOARDING_PR_NUM/merge")
|
||||||
|
|
||||||
|
# Check if merge was successful (simple check)
|
||||||
|
if echo "$MERGE_RESP" | grep -q "Pull request has been merged"; then
|
||||||
|
echo "Onboarding PR merged successfully."
|
||||||
|
else
|
||||||
|
# Fallback: check status code or response
|
||||||
|
echo "Merge response: $MERGE_RESP"
|
||||||
|
fi
|
||||||
|
|
||||||
|
# --- Step 2: Second Run (Updates) ---
|
||||||
|
echo "Running Renovate E2E (Run 2: Updates)..."
|
||||||
|
set +e
|
||||||
|
renovate --pr-hourly-limit=0 > renovate-e2e-output-2.log 2>&1
|
||||||
|
RENOVATE_EXIT_CODE=$?
|
||||||
|
set -e
|
||||||
|
cat renovate-e2e-output-2.log
|
||||||
|
|
||||||
|
if [ $RENOVATE_EXIT_CODE -ne 0 ]; then
|
||||||
|
echo "Error: Renovate command (Run 2) failed."
|
||||||
|
exit 1
|
||||||
|
fi
|
||||||
|
|
||||||
|
else
|
||||||
|
echo "No Onboarding PR found. Assuming repo is already onboarded or config exists."
|
||||||
|
fi
|
||||||
|
|
||||||
|
echo "Verifying Update PRs and Content..."
|
||||||
|
# Fetch PRs again
|
||||||
|
PRS=$(curl -s -H "Authorization: token $RENOVATE_TOKEN" "$GITEA_API_URL/repos/$REPO_OWNER/$REPO_NAME/pulls?state=open")
|
||||||
|
|
||||||
|
# Verify Nginx PR
|
||||||
|
NGINX_PR_NUM=$(echo "$PRS" | jq -r '.[] | select(.title | contains("Update nginx Docker tag")) | .number')
|
||||||
|
if [ -n "$NGINX_PR_NUM" ] && [ "$NGINX_PR_NUM" != "null" ]; then
|
||||||
|
echo "API Verification: Nginx PR found (#$NGINX_PR_NUM)."
|
||||||
|
|
||||||
|
# Verify Content
|
||||||
|
DIFF=$(curl -s -H "Authorization: token $RENOVATE_TOKEN" "$GITEA_API_URL/repos/$REPO_OWNER/$REPO_NAME/pulls/$NGINX_PR_NUM.diff")
|
||||||
|
if echo "$DIFF" | grep -q "nginx:1.27.5"; then
|
||||||
|
echo "Content Verification: Nginx version update found in diff."
|
||||||
|
else
|
||||||
|
echo "Content Verification Failed: Nginx version update NOT found in diff."
|
||||||
|
exit 1
|
||||||
|
fi
|
||||||
|
else
|
||||||
|
echo "API Verification Failed: Nginx PR not found."
|
||||||
|
exit 1
|
||||||
|
fi
|
||||||
|
|
||||||
|
# Verify Actions/Checkout PR
|
||||||
|
ACTIONS_PR_NUM=$(echo "$PRS" | jq -r '.[] | select(.title | contains("Update actions/checkout action")) | .number')
|
||||||
|
if [ -n "$ACTIONS_PR_NUM" ] && [ "$ACTIONS_PR_NUM" != "null" ]; then
|
||||||
|
echo "API Verification: Actions/Checkout PR found (#$ACTIONS_PR_NUM)."
|
||||||
|
|
||||||
|
# Verify Content
|
||||||
|
DIFF=$(curl -s -H "Authorization: token $RENOVATE_TOKEN" "$GITEA_API_URL/repos/$REPO_OWNER/$REPO_NAME/pulls/$ACTIONS_PR_NUM.diff")
|
||||||
|
if echo "$DIFF" | grep -q "actions/checkout@v4"; then
|
||||||
|
echo "Content Verification: Actions/Checkout version update found in diff."
|
||||||
|
else
|
||||||
|
echo "Content Verification Failed: Actions/Checkout version update NOT found in diff."
|
||||||
|
exit 1
|
||||||
|
fi
|
||||||
|
else
|
||||||
|
echo "API Verification Failed: Actions/Checkout PR not found."
|
||||||
|
exit 1
|
||||||
|
fi
|
||||||
|
|
||||||
|
# Verify Dependency Dashboard Issue
|
||||||
|
echo "Verifying Dependency Dashboard..."
|
||||||
|
ISSUES=$(curl -s -H "Authorization: token $RENOVATE_TOKEN" "$GITEA_API_URL/repos/$REPO_OWNER/$REPO_NAME/issues?state=open")
|
||||||
|
DASHBOARD_NUM=$(echo "$ISSUES" | jq -r '.[] | select(.title | contains("Dependency Dashboard")) | .number')
|
||||||
|
|
||||||
|
if [ -n "$DASHBOARD_NUM" ] && [ "$DASHBOARD_NUM" != "null" ]; then
|
||||||
|
echo "API Verification: Dependency Dashboard found (#$DASHBOARD_NUM)."
|
||||||
|
else
|
||||||
|
echo "API Verification Failed: Dependency Dashboard NOT found."
|
||||||
|
exit 1
|
||||||
|
fi
|
||||||
|
|
||||||
|
echo "API & Content Verification passed!"
|
||||||
131
scripts/test-renovate.sh
Executable file
131
scripts/test-renovate.sh
Executable file
@@ -0,0 +1,131 @@
|
|||||||
|
#!/bin/bash
|
||||||
|
set -e
|
||||||
|
|
||||||
|
# Configuration
|
||||||
|
GITEA_API_URL="https://gitea.kovagoadi.hu/api/v1"
|
||||||
|
REPO_OWNER="renovate-test"
|
||||||
|
REPO_NAME="test"
|
||||||
|
RENOVATE_CONFIG_FILE=${RENOVATE_CONFIG_FILE:-"/workspace/kovagoadi.hu/Renovate/renovate-config.js"}
|
||||||
|
|
||||||
|
# Ensure RENOVATE_TOKEN is available
|
||||||
|
if [ -z "$RENOVATE_TOKEN" ]; then
|
||||||
|
echo "Error: RENOVATE_TOKEN is not set."
|
||||||
|
exit 1
|
||||||
|
fi
|
||||||
|
|
||||||
|
# Cleanup function
|
||||||
|
cleanup() {
|
||||||
|
echo "Cleaning up..."
|
||||||
|
# Delete renovate.json from main branch if it exists (to reset state)
|
||||||
|
FILE_INFO=$(curl -s -H "Authorization: token $RENOVATE_TOKEN" "$GITEA_API_URL/repos/$REPO_OWNER/$REPO_NAME/contents/renovate.json?ref=main")
|
||||||
|
FILE_SHA=$(echo "$FILE_INFO" | jq -r '.sha')
|
||||||
|
|
||||||
|
if [ "$FILE_SHA" != "null" ] && [ -n "$FILE_SHA" ]; then
|
||||||
|
echo "Deleting renovate.json to reset repository state..."
|
||||||
|
curl -s -X DELETE -H "Authorization: token $RENOVATE_TOKEN" \
|
||||||
|
-H "Content-Type: application/json" \
|
||||||
|
-d "{\"message\": \"Cleanup: Delete renovate.json\", \"sha\": \"$FILE_SHA\", \"branch\": \"main\"}" \
|
||||||
|
"$GITEA_API_URL/repos/$REPO_OWNER/$REPO_NAME/contents/renovate.json"
|
||||||
|
fi
|
||||||
|
rm -f renovate-output-pre.log renovate-output-post.log
|
||||||
|
}
|
||||||
|
|
||||||
|
# Register cleanup to run on exit
|
||||||
|
trap cleanup EXIT
|
||||||
|
|
||||||
|
echo "Validating Renovate configuration..."
|
||||||
|
renovate-config-validator
|
||||||
|
|
||||||
|
# --- Phase 1: Pre-Onboarding Dry-Run ---
|
||||||
|
echo "Running Renovate dry-run (Phase 1: Pre-Onboarding)..."
|
||||||
|
# Ensure repo is clean first
|
||||||
|
cleanup
|
||||||
|
|
||||||
|
set +e
|
||||||
|
renovate --dry-run=full > renovate-output-pre.log 2>&1
|
||||||
|
RENOVATE_EXIT_CODE=$?
|
||||||
|
set -e
|
||||||
|
cat renovate-output-pre.log
|
||||||
|
|
||||||
|
if [ $RENOVATE_EXIT_CODE -ne 0 ]; then
|
||||||
|
echo "Error: Renovate dry-run (Phase 1) failed."
|
||||||
|
exit 1
|
||||||
|
fi
|
||||||
|
|
||||||
|
echo "Checking for onboarding PR in Phase 1..."
|
||||||
|
if ! grep -q "Would create onboarding PR" renovate-output-pre.log; then
|
||||||
|
echo "Error: Expected 'Would create onboarding PR' not found in Phase 1 output."
|
||||||
|
exit 1
|
||||||
|
fi
|
||||||
|
echo "Phase 1 Passed: Onboarding PR detected."
|
||||||
|
|
||||||
|
# --- Phase 2: Onboarding Simulation ---
|
||||||
|
echo "Simulating Onboarding..."
|
||||||
|
# Content of renovate.json (base64 encoded for API if needed, but Gitea API takes content string)
|
||||||
|
# We'll use a simple config similar to the repo's renovate.json
|
||||||
|
CONTENT=$(cat <<EOF
|
||||||
|
{
|
||||||
|
"\$schema": "https://docs.renovatebot.com/renovate-schema.json",
|
||||||
|
"extends": [
|
||||||
|
"config:recommended"
|
||||||
|
],
|
||||||
|
"pinDigests": true
|
||||||
|
}
|
||||||
|
EOF
|
||||||
|
)
|
||||||
|
# Base64 encode content
|
||||||
|
CONTENT_B64=$(echo "$CONTENT" | base64 -w 0)
|
||||||
|
|
||||||
|
echo "Pushing renovate.json to $REPO_OWNER/$REPO_NAME..."
|
||||||
|
CREATE_RESP=$(curl -s -X POST -H "Authorization: token $RENOVATE_TOKEN" \
|
||||||
|
-H "Content-Type: application/json" \
|
||||||
|
-d "{\"content\": \"$CONTENT_B64\", \"message\": \"Simulate Onboarding: Add renovate.json\", \"branch\": \"main\"}" \
|
||||||
|
"$GITEA_API_URL/repos/$REPO_OWNER/$REPO_NAME/contents/renovate.json")
|
||||||
|
|
||||||
|
if echo "$CREATE_RESP" | grep -q "sha"; then
|
||||||
|
echo "renovate.json pushed successfully."
|
||||||
|
else
|
||||||
|
echo "Error pushing renovate.json: $CREATE_RESP"
|
||||||
|
exit 1
|
||||||
|
fi
|
||||||
|
|
||||||
|
# --- Phase 3: Post-Onboarding Dry-Run ---
|
||||||
|
echo "Running Renovate dry-run (Phase 3: Post-Onboarding)..."
|
||||||
|
set +e
|
||||||
|
renovate --dry-run=full > renovate-output-post.log 2>&1
|
||||||
|
RENOVATE_EXIT_CODE=$?
|
||||||
|
set -e
|
||||||
|
cat renovate-output-post.log
|
||||||
|
|
||||||
|
if [ $RENOVATE_EXIT_CODE -ne 0 ]; then
|
||||||
|
echo "Error: Renovate dry-run (Phase 3) failed."
|
||||||
|
exit 1
|
||||||
|
fi
|
||||||
|
|
||||||
|
# Specific assertions based on the test repo state (now onboarded)
|
||||||
|
echo "Checking for expected nginx update..."
|
||||||
|
if ! grep -q "renovate/nginx-" renovate-output-post.log; then
|
||||||
|
echo "Error: Expected 'renovate/nginx-' branch not found in Phase 3 output."
|
||||||
|
exit 1
|
||||||
|
fi
|
||||||
|
|
||||||
|
echo "Checking for nginx PR title..."
|
||||||
|
if ! grep -q "Update nginx Docker tag to" renovate-output-post.log; then
|
||||||
|
echo "Error: Expected PR title 'Update nginx Docker tag to...' not found."
|
||||||
|
exit 1
|
||||||
|
fi
|
||||||
|
|
||||||
|
echo "Checking for expected actions/checkout update..."
|
||||||
|
if ! grep -q "renovate/actions-checkout-" renovate-output-post.log; then
|
||||||
|
echo "Error: Expected 'renovate/actions-checkout-' branch not found in Phase 3 output."
|
||||||
|
exit 1
|
||||||
|
fi
|
||||||
|
|
||||||
|
echo "Checking for actions/checkout PR title..."
|
||||||
|
if ! grep -q "Update actions/checkout action to" renovate-output-post.log; then
|
||||||
|
echo "Error: Expected PR title 'Update actions/checkout action to...' not found."
|
||||||
|
exit 1
|
||||||
|
fi
|
||||||
|
|
||||||
|
echo "Phase 3 Passed: Update PRs detected."
|
||||||
|
echo "All Dry-Run Tests Passed!"
|
||||||
Reference in New Issue
Block a user