mirror of
https://github.com/Unleash/unleash.git
synced 2025-07-02 01:17:58 +02:00
chore: openapi-diff on PRs (#10100)
This commit is contained in:
parent
7b0cae2b3e
commit
2d228eea76
2
.github/docker-compose.test.yml
vendored
2
.github/docker-compose.test.yml
vendored
@ -26,7 +26,7 @@ services:
|
|||||||
unleash:
|
unleash:
|
||||||
condition: service_healthy
|
condition: service_healthy
|
||||||
unleash:
|
unleash:
|
||||||
image: unleashorg/unleash-enterprise:latest
|
image: unleashorg/${UNLEASH_VERSION:-unleash-enterprise:latest}
|
||||||
pull_policy: "always"
|
pull_policy: "always"
|
||||||
expose:
|
expose:
|
||||||
- "4242"
|
- "4242"
|
||||||
|
1
.github/workflows/build.yaml
vendored
1
.github/workflows/build.yaml
vendored
@ -12,6 +12,7 @@ on:
|
|||||||
- frontend/**
|
- frontend/**
|
||||||
- website/**
|
- website/**
|
||||||
- coverage/**
|
- coverage/**
|
||||||
|
|
||||||
jobs:
|
jobs:
|
||||||
build:
|
build:
|
||||||
runs-on: ubuntu-latest
|
runs-on: ubuntu-latest
|
||||||
|
176
.github/workflows/openapi-diff.yaml
vendored
Normal file
176
.github/workflows/openapi-diff.yaml
vendored
Normal file
@ -0,0 +1,176 @@
|
|||||||
|
name: OpenAPI Diff
|
||||||
|
|
||||||
|
on:
|
||||||
|
pull_request:
|
||||||
|
paths:
|
||||||
|
- src/lib/**
|
||||||
|
- .github/workflows/openapi-diff.yaml
|
||||||
|
workflow_dispatch:
|
||||||
|
inputs:
|
||||||
|
stable_version:
|
||||||
|
description: 'Stable Unleash version to compare against (e.g. unleash-server:6.9.3 or unleash-enterprise:6.10.0)'
|
||||||
|
required: false
|
||||||
|
default: 'unleash-server:latest'
|
||||||
|
|
||||||
|
jobs:
|
||||||
|
generate-openapi-stable:
|
||||||
|
name: Generate OpenAPI (stable)
|
||||||
|
runs-on: ubuntu-latest
|
||||||
|
steps:
|
||||||
|
- uses: actions/checkout@v4
|
||||||
|
- name: Start Unleash test instance
|
||||||
|
run: |
|
||||||
|
docker compose -f .github/docker-compose.test.yml up -d --wait -t 90
|
||||||
|
env:
|
||||||
|
FRONTEND_TEST_LICENSE: ${{ secrets.FRONTEND_TEST_LICENSE }}
|
||||||
|
UNLEASH_VERSION: ${{ github.event.inputs.stable_version || 'unleash-server:main-edge' }}
|
||||||
|
CHECK_VERSION: 'false'
|
||||||
|
- name: Wait for Unleash to be ready
|
||||||
|
run: |
|
||||||
|
for i in {1..30}; do
|
||||||
|
if curl -sf http://localhost:3000/health; then
|
||||||
|
echo "Unleash is up!";
|
||||||
|
exit 0
|
||||||
|
fi
|
||||||
|
echo "Waiting for Unleash...";
|
||||||
|
sleep 2
|
||||||
|
done
|
||||||
|
echo "Unleash did not become ready in time."
|
||||||
|
exit 1
|
||||||
|
- name: Download OpenAPI spec from (${{ github.event.inputs.stable_version || 'tip of main' }})
|
||||||
|
run: curl -sSL -o openapi-stable.json "localhost:3000/docs/openapi.json"
|
||||||
|
- name: Upload openapi-stable.json
|
||||||
|
uses: actions/upload-artifact@v4
|
||||||
|
with:
|
||||||
|
name: openapi-stable
|
||||||
|
path: openapi-stable.json
|
||||||
|
|
||||||
|
generate-openapi-current:
|
||||||
|
name: Generate OpenAPI (current branch)
|
||||||
|
runs-on: ubuntu-latest
|
||||||
|
services:
|
||||||
|
# Label used to access the service container
|
||||||
|
postgres:
|
||||||
|
# Docker Hub image
|
||||||
|
image: postgres
|
||||||
|
# Provide the password for postgres
|
||||||
|
env:
|
||||||
|
POSTGRES_PASSWORD: postgres
|
||||||
|
POSTGRES_INITDB_ARGS: "--no-sync"
|
||||||
|
# Set health checks to wait until postgres has started
|
||||||
|
ports:
|
||||||
|
- 5432:5432
|
||||||
|
options: >-
|
||||||
|
--health-cmd pg_isready --health-interval 10s --health-timeout 5s --health-retries 5
|
||||||
|
steps:
|
||||||
|
- uses: actions/checkout@v4
|
||||||
|
- name: Install node
|
||||||
|
uses: actions/setup-node@v4
|
||||||
|
with:
|
||||||
|
node-version: 22.x
|
||||||
|
- name: Install dependencies
|
||||||
|
run: |
|
||||||
|
yarn install --immutable
|
||||||
|
- name: Start Unleash test instance
|
||||||
|
run: |
|
||||||
|
# fake frontend build
|
||||||
|
mkdir frontend/build
|
||||||
|
touch frontend/build/index.html
|
||||||
|
touch frontend/build/favicon.ico
|
||||||
|
# end fake frontend build
|
||||||
|
|
||||||
|
# start unleash in background
|
||||||
|
NODE_ENV=openapi yarn dev:backend &
|
||||||
|
env:
|
||||||
|
DATABASE_URL: postgres://postgres:postgres@localhost:5432/postgres
|
||||||
|
DATABASE_SSL: 'false'
|
||||||
|
CHECK_VERSION: 'false'
|
||||||
|
- name: Wait for Unleash to be ready
|
||||||
|
run: |
|
||||||
|
for i in {1..30}; do
|
||||||
|
if curl -sf http://localhost:4242/health; then
|
||||||
|
echo "Unleash is up!";
|
||||||
|
break;
|
||||||
|
fi
|
||||||
|
echo "Waiting for Unleash...";
|
||||||
|
sleep 2
|
||||||
|
done
|
||||||
|
- name: Download OpenAPI spec (current branch)
|
||||||
|
run: curl -sSL -o openapi-current.json localhost:4242/docs/openapi.json
|
||||||
|
- name: Upload openapi-current.json
|
||||||
|
uses: actions/upload-artifact@v4
|
||||||
|
with:
|
||||||
|
name: openapi-current
|
||||||
|
path: openapi-current.json
|
||||||
|
|
||||||
|
openapi-diff:
|
||||||
|
name: OpenAPI Diff
|
||||||
|
runs-on: ubuntu-latest
|
||||||
|
needs: [generate-openapi-current, generate-openapi-stable]
|
||||||
|
if: github.event_name == 'pull_request'
|
||||||
|
steps:
|
||||||
|
- name: Download openapi-current.json
|
||||||
|
uses: actions/download-artifact@v4
|
||||||
|
with:
|
||||||
|
name: openapi-current
|
||||||
|
- name: Download openapi-stable.json
|
||||||
|
uses: actions/download-artifact@v4
|
||||||
|
with:
|
||||||
|
name: openapi-stable
|
||||||
|
- name: Run OpenAPI diff
|
||||||
|
id: diff
|
||||||
|
run: |
|
||||||
|
docker run --rm -t -v $(pwd):/specs:ro tufin/oasdiff changelog --format markdown /specs/openapi-stable.json /specs/openapi-current.json > openapi-diff.txt || true
|
||||||
|
# then output in a format that can be used in GitHub Actions
|
||||||
|
docker run --rm -t -v $(pwd):/specs:ro tufin/oasdiff changelog --format githubactions /specs/openapi-stable.json /specs/openapi-current.json
|
||||||
|
- name: Comment on PR with OpenAPI diff
|
||||||
|
uses: actions/github-script@v7
|
||||||
|
with:
|
||||||
|
script: |
|
||||||
|
const fs = require('fs');
|
||||||
|
const diff = fs.readFileSync('openapi-diff.txt', 'utf8');
|
||||||
|
const diffLines = diff.split('\n').filter(line => line.trim() !== '' && !line.startsWith('#')).length;
|
||||||
|
const marker = '### OpenAPI Diff';
|
||||||
|
// Get all comments on the PR
|
||||||
|
const { data: comments } = await github.rest.issues.listComments({
|
||||||
|
issue_number: context.issue.number,
|
||||||
|
owner: context.repo.owner,
|
||||||
|
repo: context.repo.repo,
|
||||||
|
});
|
||||||
|
// Find existing OpenAPI Diff comment
|
||||||
|
const existing = comments.find(c => c.body && c.body.includes(marker) && c.user.type === 'Bot');
|
||||||
|
let body;
|
||||||
|
if (diffLines > 300) {
|
||||||
|
body = `${marker} too long, check the this task output for details.`;
|
||||||
|
console.log(diff);
|
||||||
|
} else if (diffLines > 0) {
|
||||||
|
body = `${marker}\n\n\`\`\`diff\n${diff}\n\`\`\``;
|
||||||
|
} else {
|
||||||
|
body = null;
|
||||||
|
}
|
||||||
|
if (body) {
|
||||||
|
if (existing) {
|
||||||
|
await github.rest.issues.updateComment({
|
||||||
|
comment_id: existing.id,
|
||||||
|
owner: context.repo.owner,
|
||||||
|
repo: context.repo.repo,
|
||||||
|
body,
|
||||||
|
});
|
||||||
|
} else {
|
||||||
|
await github.rest.issues.createComment({
|
||||||
|
issue_number: context.issue.number,
|
||||||
|
owner: context.repo.owner,
|
||||||
|
repo: context.repo.repo,
|
||||||
|
body,
|
||||||
|
});
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
console.log('No significant changes detected in OpenAPI spec.');
|
||||||
|
if (existing) {
|
||||||
|
await github.rest.issues.deleteComment({
|
||||||
|
comment_id: existing.id,
|
||||||
|
owner: context.repo.owner,
|
||||||
|
repo: context.repo.repo,
|
||||||
|
});
|
||||||
|
}
|
||||||
|
}
|
@ -40,7 +40,7 @@
|
|||||||
"build:frontend:if-needed": "./scripts/build-frontend-if-needed.sh",
|
"build:frontend:if-needed": "./scripts/build-frontend-if-needed.sh",
|
||||||
"build": "yarn run clean && concurrently \"yarn:copy-templates\" \"yarn:build:frontend\" \"yarn:build:backend\"",
|
"build": "yarn run clean && concurrently \"yarn:copy-templates\" \"yarn:build:frontend\" \"yarn:build:backend\"",
|
||||||
"dev:vite": "TZ=UTC NODE_ENV=development vite-node src/server-dev.ts",
|
"dev:vite": "TZ=UTC NODE_ENV=development vite-node src/server-dev.ts",
|
||||||
"dev:backend": "TZ=UTC NODE_ENV=development tsc-watch --onEmit \"copyfiles -u 2 src/migrations/package.json dist/migrations\" --onSuccess \"node dist/server-dev.js\"",
|
"dev:backend": "TZ=UTC NODE_ENV=${NODE_ENV:-development} tsc-watch --onEmit \"copyfiles -u 2 src/migrations/package.json dist/migrations\" --onSuccess \"node dist/server-dev.js\"",
|
||||||
"dev:frontend": "wait-on tcp:4242 && yarn --cwd ./frontend run dev",
|
"dev:frontend": "wait-on tcp:4242 && yarn --cwd ./frontend run dev",
|
||||||
"dev:frontend:cloud": "UNLEASH_BASE_PATH=/demo/ yarn run dev:frontend",
|
"dev:frontend:cloud": "UNLEASH_BASE_PATH=/demo/ yarn run dev:frontend",
|
||||||
"dev": "concurrently \"yarn:dev:backend\" \"yarn:dev:frontend\"",
|
"dev": "concurrently \"yarn:dev:backend\" \"yarn:dev:frontend\"",
|
||||||
|
Loading…
Reference in New Issue
Block a user