From 6d1ee29194becffa48cde8343b2081b8d0e181cc Mon Sep 17 00:00:00 2001 From: Mads Bisgaard <126242332+bisgaard-itis@users.noreply.github.com> Date: Tue, 10 Dec 2024 08:21:28 +0100 Subject: [PATCH] =?UTF-8?q?=E2=99=BB=EF=B8=8F=20refactor=20github=20workfl?= =?UTF-8?q?ow=20file=20(#6926)?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- .github/workflows/ci-testing-deploy.yml | 81 ----------------- .github/workflows/ci-testing-pull-request.yml | 87 +++++++++++++++++++ services/catalog/openapi.json | 11 ++- 3 files changed, 97 insertions(+), 82 deletions(-) create mode 100644 .github/workflows/ci-testing-pull-request.yml diff --git a/.github/workflows/ci-testing-deploy.yml b/.github/workflows/ci-testing-deploy.yml index 50765b74cdc..aa1efbee7a9 100644 --- a/.github/workflows/ci-testing-deploy.yml +++ b/.github/workflows/ci-testing-deploy.yml @@ -2661,84 +2661,3 @@ jobs: env: TAG_PREFIX: hotfix-staging-github run: ./ci/deploy/dockerhub-deploy.bash -n - - system-api-specs: - needs: [changes] - if: ${{ needs.changes.outputs.anything-py == 'true' || github.event_name == 'push' }} - timeout-minutes: 10 - name: "[sys] check api-specs are up to date" - runs-on: ubuntu-latest - steps: - - name: Ensure job passes if not PR # ensure pass so upstream jobs which depend on this will run (dockerhub deployment) - if: ${{ github.event.pull_request == null }} - run: echo "::notice Passing job because not in PR"; exit 0 - - name: setup python environment - uses: actions/setup-python@v5 - with: - python-version: "3.11" - - name: install uv - uses: astral-sh/setup-uv@v4 - with: - version: "0.4.x" - enable-cache: false - - name: checkout source branch - uses: actions/checkout@v4 - - name: Regenerate specs and check - run: | - uv venv .venv && source .venv/bin/activate - make openapi-specs - ./ci/github/helpers/openapi-specs-diff.bash diff \ - https://raw.githubusercontent.com/${{ github.event.pull_request.head.repo.full_name }}/refs/heads/${{ github.event.pull_request.head.ref }} \ - . - - system-backwards-compatibility: - needs: [changes, system-api-specs] - if: ${{ needs.changes.outputs.anything-py == 'true' || github.event_name == 'push' }} - timeout-minutes: 10 - name: "[sys] api-server backwards compatibility" - runs-on: ubuntu-latest - steps: - - name: Ensure job passes if not PR # ensure pass so upstream jobs which depend on this will run (dockerhub deployment) - if: ${{ github.event.pull_request == null }} - run: echo "::notice Passing job because not in PR"; exit 0 - - name: setup python environment - uses: actions/setup-python@v5 - with: - python-version: "3.11" - - name: install uv - uses: astral-sh/setup-uv@v4 - with: - version: "0.4.x" - enable-cache: false - - name: checkout - uses: actions/checkout@v4 - - name: check api-server backwards compatibility - run: | - ./scripts/openapi-diff.bash breaking --fail-on ERR\ - https://raw.githubusercontent.com/${{ github.event.pull_request.base.repo.full_name }}/refs/heads/${{ github.event.pull_request.base.ref }}/services/api-server/openapi.json \ - /specs/services/api-server/openapi.json - - api-spec-backwards-compatibility: - needs: [changes, system-api-specs] - if: ${{ needs.changes.outputs.anything-py == 'true' && github.event_name == 'push' && github.event.pull_request != null }} - continue-on-error: true - timeout-minutes: 10 - name: "api-specs-backwards-compatibility" - runs-on: ubuntu-latest - steps: - - name: setup python environment - uses: actions/setup-python@v5 - with: - python-version: "3.11" - - name: install uv - uses: astral-sh/setup-uv@v4 - with: - version: "0.4.x" - enable-cache: false - - name: checkout - uses: actions/checkout@v4 - - name: Check openapi-specs backwards compatibility - run: | - ./ci/github/helpers/openapi-specs-diff.bash breaking \ - https://raw.githubusercontent.com/${{ github.event.pull_request.base.repo.full_name }}/refs/heads/${{ github.event.pull_request.base.ref }} \ - . diff --git a/.github/workflows/ci-testing-pull-request.yml b/.github/workflows/ci-testing-pull-request.yml new file mode 100644 index 00000000000..3d877cb091a --- /dev/null +++ b/.github/workflows/ci-testing-pull-request.yml @@ -0,0 +1,87 @@ +# This workflow holds jobs which are required to pass before merging into master + +name: PR CI +on: + pull_request: + branches: + - "*" + # https://github.blog/changelog/2023-02-08-pull-request-merge-queue-public-beta/ + merge_group: + branches: + - "master" + +concurrency: + group: ${{ github.workflow }}-${{ github.ref }} + cancel-in-progress: true + +jobs: + api-specs: + timeout-minutes: 10 + name: "check oas' are up to date" + runs-on: ubuntu-latest + steps: + - name: setup python environment + uses: actions/setup-python@v5 + with: + python-version: "3.11" + - name: install uv + uses: astral-sh/setup-uv@v4 + with: + version: "0.4.x" + enable-cache: false + - name: checkout source branch + uses: actions/checkout@v4 + - name: Regenerate specs and check + run: | + uv venv .venv && source .venv/bin/activate + make openapi-specs + ./ci/github/helpers/openapi-specs-diff.bash diff \ + https://raw.githubusercontent.com/${{ github.event.pull_request.head.repo.full_name }}/refs/heads/${{ github.event.pull_request.head.ref }} \ + . + + api-server-backwards-compatibility: + needs: api-specs + timeout-minutes: 10 + name: "api-server backwards compatibility" + runs-on: ubuntu-latest + steps: + - name: setup python environment + uses: actions/setup-python@v5 + with: + python-version: "3.11" + - name: install uv + uses: astral-sh/setup-uv@v4 + with: + version: "0.4.x" + enable-cache: false + - name: checkout + uses: actions/checkout@v4 + - name: check api-server backwards compatibility + run: | + ./scripts/openapi-diff.bash breaking --fail-on ERR\ + https://raw.githubusercontent.com/${{ github.event.pull_request.base.repo.full_name }}/refs/heads/${{ github.event.pull_request.base.ref }}/services/api-server/openapi.json \ + /specs/services/api-server/openapi.json + + oas-backwards-compatibility: + needs: api-specs + continue-on-error: true + timeout-minutes: 10 + name: "oas backwards compatibility" + runs-on: ubuntu-latest + steps: + - name: setup python environment + uses: actions/setup-python@v5 + with: + python-version: "3.11" + - name: install uv + uses: astral-sh/setup-uv@v4 + with: + version: "0.4.x" + enable-cache: false + - name: checkout + uses: actions/checkout@v4 + - name: Check openapi-specs backwards compatibility + run: | + ./ci/github/helpers/openapi-specs-diff.bash breaking \ + https://raw.githubusercontent.com/${{ github.event.pull_request.base.repo.full_name }}/refs/heads/${{ github.event.pull_request.base.ref }} \ + . diff --git a/services/catalog/openapi.json b/services/catalog/openapi.json index 5f5204053cd..ad9422734c8 100644 --- a/services/catalog/openapi.json +++ b/services/catalog/openapi.json @@ -628,11 +628,17 @@ }, "image": { "type": "string", + "maxLength": 2083, + "minLength": 1, + "format": "uri", "title": "Image", "description": "Url to the badge" }, "url": { "type": "string", + "maxLength": 2083, + "minLength": 1, + "format": "uri", "title": "Url", "description": "Link to the status" } @@ -2843,7 +2849,10 @@ "thumbnail": { "anyOf": [ { - "type": "string" + "type": "string", + "maxLength": 2083, + "minLength": 1, + "format": "uri" }, { "type": "null"