snapshot-release.yml 5.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161
  1. name: Create a Snapshot Release
  2. on:
  3. workflow_dispatch:
  4. issue_comment:
  5. types: [created]
  6. defaults:
  7. run:
  8. shell: bash
  9. env:
  10. TURBO_TOKEN: ${{ secrets.TURBO_TOKEN }}
  11. TURBO_TEAM: ${{ secrets.TURBO_TEAM }}
  12. FORCE_COLOR: 1
  13. jobs:
  14. snapshot-release:
  15. name: Create a snapshot release of a pull request
  16. if: ${{ github.repository_owner == 'withastro' && github.event.issue.pull_request && (contains(github.event.comment.body, '!preview') || contains(github.event.comment.body, '/preview') || contains(github.event.comment.body, '!snapshot') || contains(github.event.comment.body, '/snapshot')) }}
  17. runs-on: ubuntu-latest
  18. permissions:
  19. contents: read
  20. id-token: write
  21. issues: write
  22. pull-requests: write
  23. steps:
  24. - name: "Check if user has admin access (only admins can publish snapshot releases)."
  25. uses: "lannonbr/repo-permission-check-action@2.0.0"
  26. with:
  27. permission: "admin"
  28. env:
  29. GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }}
  30. - name: Extract the snapshot name from comment body
  31. id: getSnapshotName
  32. uses: actions/github-script@v7
  33. with:
  34. script: |
  35. const { body } = context.payload.comment;
  36. const PREVIEW_RE = /^[!\/](?:preview|snapshot)\s+(\S*)\s*$/gim;
  37. const [_, name] = PREVIEW_RE.exec(body) ?? [];
  38. if (name) return name;
  39. const error = 'Invalid command. Expected: "/preview <snapshot-name>"'
  40. github.rest.issues.createComment({
  41. issue_number: context.issue.number,
  42. owner: context.repo.owner,
  43. repo: context.repo.repo,
  44. body: error,
  45. })
  46. core.setFailed(error)
  47. result-encoding: string
  48. - name: resolve pr refs
  49. id: refs
  50. uses: eficode/resolve-pr-refs@main
  51. with:
  52. token: ${{ secrets.GITHUB_TOKEN }}
  53. - uses: actions/checkout@v4
  54. with:
  55. ref: ${{ steps.refs.outputs.head_ref }}
  56. fetch-depth: 0
  57. - run: git fetch origin main:main
  58. - name: Setup PNPM
  59. uses: pnpm/action-setup@v2
  60. - name: Setup Node
  61. uses: actions/setup-node@v4
  62. with:
  63. node-version: 18
  64. registry-url: "https://registry.npmjs.org"
  65. cache: "pnpm"
  66. - name: Install dependencies
  67. run: pnpm install
  68. - name: Build Packages
  69. run: pnpm run build
  70. - name: Bump Package Versions
  71. id: changesets
  72. run: |
  73. pnpm exec changeset status --output status.output.json 2>&1
  74. pnpm exec changeset version --snapshot ${{ steps.getSnapshotName.outputs.result }}
  75. EOF=$(dd if=/dev/urandom bs=15 count=1 status=none | base64)
  76. echo "status<<$EOF" >> $GITHUB_OUTPUT
  77. echo "$(cat status.output.json)" >> $GITHUB_OUTPUT
  78. echo "$EOF" >> $GITHUB_OUTPUT
  79. env:
  80. # Needs access to run the script
  81. GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }}
  82. # Disable color
  83. FORCE_COLOR: 0
  84. NO_COLOR: 1
  85. - name: Publish Release
  86. id: publish
  87. run: |
  88. GITHUB_ACTIONS=0 pnpm run build > build.output.txt 2>&1
  89. pnpm exec changeset publish --tag experimental--${{ steps.getSnapshotName.outputs.result }} > publish.output.txt 2>&1
  90. EOF=$(dd if=/dev/urandom bs=15 count=1 status=none | base64)
  91. echo "build<<$EOF" >> $GITHUB_OUTPUT
  92. echo "$(cat build.output.txt)" >> $GITHUB_OUTPUT
  93. echo "$EOF" >> $GITHUB_OUTPUT
  94. cat build.output.txt
  95. echo "publish<<$EOF" >> $GITHUB_OUTPUT
  96. echo "$(cat publish.output.txt)" >> $GITHUB_OUTPUT
  97. echo "$EOF" >> $GITHUB_OUTPUT
  98. cat publish.output.txt
  99. env:
  100. # Needs access to publish to npm
  101. NPM_TOKEN: ${{ secrets.NPM_TOKEN }}
  102. NODE_AUTH_TOKEN: ${{ secrets.NPM_TOKEN }}
  103. # Disable color
  104. FORCE_COLOR: 0
  105. NO_COLOR: 1
  106. - name: Pull Request Notification
  107. uses: actions/github-script@v7
  108. env:
  109. TAG: ${{ steps.getSnapshotName.outputs.result }}
  110. STATUS_DATA: ${{ steps.changesets.outputs.status }}
  111. BUILD_LOG: ${{ steps.publish.outputs.build }}
  112. PUBLISH_LOG: ${{ steps.publish.outputs.publish }}
  113. with:
  114. script: |
  115. let changeset = { releases: [] };
  116. try {
  117. changeset = JSON.parse(process.env.STATUS_DATA);
  118. } catch (e) {}
  119. let message = 'Snapshots have been released for the following packages:'
  120. for (const release of changeset.releases) {
  121. if (release.type === 'none') continue;
  122. message += `\n- \`${release.name}@experimental--${process.env.TAG}\``;
  123. }
  124. function details(title, body) {
  125. message += '\n';
  126. message += `<details><summary><strong>${title}</strong></summary>`
  127. message += '\n\n```\n';
  128. message += body;
  129. message += '\n```\n\n</details>';
  130. }
  131. details('Publish Log', process.env.PUBLISH_LOG);
  132. details('Build Log', process.env.BUILD_LOG);
  133. github.rest.issues.createComment({
  134. issue_number: context.issue.number,
  135. owner: context.repo.owner,
  136. repo: context.repo.repo,
  137. body: message,
  138. })