openapi-diff.yml 2.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475
  1. name: openapi-diff
  2. on:
  3. pull_request:
  4. # Cancel in progress workflows on pull_requests.
  5. # https://docs.github.com/en/actions/using-jobs/using-concurrency#example-using-a-fallback-value
  6. concurrency:
  7. group: ${{ github.workflow }}-${{ github.head_ref || github.run_id }}
  8. cancel-in-progress: true
  9. # hack for https://github.com/actions/cache/issues/810#issuecomment-1222550359
  10. env:
  11. SEGMENT_DOWNLOAD_TIMEOUT_MINS: 3
  12. jobs:
  13. check-diff:
  14. name: (Optional) Shows the difference between the prod and dev schema
  15. runs-on: ubuntu-24.04
  16. timeout-minutes: 90
  17. steps:
  18. - uses: actions/checkout@692973e3d937129bcbf40652eb9f2f61becf3332 # v4.1.7
  19. - name: Check for python file changes
  20. uses: dorny/paths-filter@0bc4621a3135347011ad047f9ecf449bf72ce2bd # v3.0.0
  21. id: changes
  22. with:
  23. token: ${{ github.token }}
  24. filters: .github/file-filters.yml
  25. - name: Setup sentry env
  26. uses: ./.github/actions/setup-sentry
  27. with:
  28. mode: migrations
  29. if: steps.changes.outputs.api_docs == 'true'
  30. - name: Checkout getsentry/sentry-api-schema
  31. uses: actions/checkout@692973e3d937129bcbf40652eb9f2f61becf3332 # v4.1.7
  32. if: steps.changes.outputs.api_docs == 'true'
  33. with:
  34. ref: 'main'
  35. repository: getsentry/sentry-api-schema
  36. path: sentry-api-schema
  37. - uses: actions/setup-node@1e60f620b9541d16bece96c5465dc8ee9832be0b # v4
  38. id: setup-node
  39. with:
  40. node-version-file: '.volta.json'
  41. - name: Build OpenAPI Derefed JSON
  42. if: steps.changes.outputs.api_docs == 'true'
  43. # install ts-node for ts build scripts to execute properly without potentially installing
  44. # conflicting deps when running scripts locally
  45. # see: https://github.com/getsentry/sentry/pull/32328/files
  46. run: |
  47. yarn add ts-node && make build-api-docs
  48. - name: Compare OpenAPI Derefed JSON
  49. if: steps.changes.outputs.api_docs == 'true'
  50. run: |
  51. npx json-diff@0.5.4 --color sentry-api-schema/openapi-derefed.json tests/apidocs/openapi-derefed.json
  52. - name: Dump RPC schema for new version
  53. id: newschema
  54. if: steps.changes.outputs.api_docs == 'true'
  55. run: |
  56. mkdir schemas
  57. sentry rpcschema > rpc_method_schema.json
  58. - name: Output RPC schema comparison
  59. uses: oasdiff/oasdiff-action/breaking@a2ff6682b27d175162a74c09ace8771bd3d512f8 # A few commits after v0.0.19 to get fixes
  60. if: steps.changes.outputs.api_docs == 'true'
  61. with:
  62. base: sentry-api-schema/rpc_method_schema.json
  63. revision: ./rpc_method_schema.json
  64. fail-on: WARN