12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182 |
- name: openapi-diff
- on:
- pull_request:
- # Cancel in progress workflows on pull_requests.
- # https://docs.github.com/en/actions/using-jobs/using-concurrency#example-using-a-fallback-value
- concurrency:
- group: ${{ github.workflow }}-${{ github.head_ref || github.run_id }}
- cancel-in-progress: true
- # hack for https://github.com/actions/cache/issues/810#issuecomment-1222550359
- env:
- SEGMENT_DOWNLOAD_TIMEOUT_MINS: 3
- jobs:
- check-diff:
- name: build api
- runs-on: ubuntu-22.04
- timeout-minutes: 90
- steps:
- - uses: actions/checkout@b4ffde65f46336ab88eb53be808477a3936bae11 # v4.1.1
- - name: Check for python file changes
- uses: dorny/paths-filter@0bc4621a3135347011ad047f9ecf449bf72ce2bd # v3.0.0
- id: changes
- with:
- token: ${{ github.token }}
- filters: .github/file-filters.yml
- - name: Setup sentry env
- uses: ./.github/actions/setup-sentry
- if: steps.changes.outputs.api_docs == 'true'
- - name: Checkout getsentry/sentry-api-schema
- uses: actions/checkout@b4ffde65f46336ab88eb53be808477a3936bae11 # v4.1.1
- if: steps.changes.outputs.api_docs == 'true'
- with:
- ref: 'main'
- repository: getsentry/sentry-api-schema
- path: sentry-api-schema
- - uses: getsentry/action-setup-volta@e4939d337b83760d13a9d7030a6f68c9d0ee7581 # v2.0.0
- if: steps.changes.outputs.api_docs == 'true'
- - name: Build OpenAPI Derefed JSON
- if: steps.changes.outputs.api_docs == 'true'
- # install ts-node for ts build scripts to execute properly without potentially installing
- # conflicting deps when running scripts locally
- # see: https://github.com/getsentry/sentry/pull/32328/files
- run: |
- yarn add ts-node && make build-api-docs
- - name: Compare OpenAPI Derefed JSON
- if: steps.changes.outputs.api_docs == 'true'
- run: |
- npx json-diff@0.5.4 --color sentry-api-schema/openapi-derefed.json tests/apidocs/openapi-derefed.json
- # Do RPC compatibility checks. Combined with public API audits
- # to avoid workflow/job setup overhead.
- - name: Dump RPC schema for new version
- id: newschema
- if: steps.changes.outputs.api_docs == 'true'
- run: |
- mkdir schemas
- sentry rpcschema --partial > schemas/new_schema.json
- - name: Dump RPC schema for master
- id: oldschema
- if: steps.changes.outputs.api_docs == 'true'
- run: |
- git fetch origin
- git switch master
- sentry rpcschema --partial > schemas/old_schema.json
- - name: Invoke oasdiff on RPC schemas
- uses: oasdiff/oasdiff-action/breaking@fc826b9f0d21b85b085842521c7a8cc445412c08 # v0.0.19
- if: steps.changes.outputs.api_docs == 'true'
- with:
- base: ./schemas/old_schema.json
- revision: ./schemas/new_schema.json
- format: 'text'
- fail-on-diff: true
|