|
18 | 18 | workflow_dispatch: |
19 | 19 |
|
20 | 20 | jobs: |
21 | | - release: |
| 21 | + build: |
22 | 22 | runs-on: ubuntu-22.04 |
23 | | - environment: release |
24 | | - permissions: |
25 | | - # `gh release` requires write permission on repo contents |
26 | | - contents: write |
| 23 | + outputs: |
| 24 | + anchor: ${{ steps.version.outputs.anchor }} |
| 25 | + tag: ${{ steps.version.outputs.tag }} |
| 26 | + version: ${{ steps.version.outputs.version }} |
27 | 27 | steps: |
28 | 28 | - name: Get code |
29 | 29 | uses: actions/checkout@v4 |
@@ -52,29 +52,59 @@ jobs: |
52 | 52 | echo "tag=$TAG" >> $GITHUB_OUTPUT |
53 | 53 | echo "anchor=${TAG//[^[:alnum:]]/-}" >> $GITHUB_OUTPUT |
54 | 54 |
|
55 | | - - name: Build |
| 55 | + - name: Build distribution |
56 | 56 | run: | |
57 | 57 | rm -rf build dist django_anymail.egg-info |
58 | 58 | python -m build |
| 59 | +
|
| 60 | + - name: Check metadata |
| 61 | + run: | |
59 | 62 | python -m twine check dist/* |
60 | 63 |
|
| 64 | + - name: Upload build artifacts |
| 65 | + uses: actions/upload-artifact@v4 |
| 66 | + with: |
| 67 | + name: dist |
| 68 | + path: dist/ |
| 69 | + retention-days: 7 |
| 70 | + |
| 71 | + publish: |
| 72 | + needs: [build] |
| 73 | + runs-on: ubuntu-22.04 |
| 74 | + environment: |
| 75 | + name: pypi |
| 76 | + url: https://pypi.org/p/django-anymail |
| 77 | + permissions: |
| 78 | + # Required for PyPI trusted publishing |
| 79 | + id-token: write |
| 80 | + steps: |
| 81 | + - name: Download build artifacts |
| 82 | + uses: actions/download-artifact@v4 |
| 83 | + with: |
| 84 | + name: dist |
| 85 | + path: dist/ |
61 | 86 | - name: Publish to PyPI |
62 | | - env: |
63 | | - TWINE_USERNAME: __token__ |
64 | | - TWINE_PASSWORD: ${{ secrets.PYPI_API_TOKEN }} |
65 | | - # For test PyPI, set release var PYPI_REPOSITORY_URL=https://test.pypi.org/legacy/. |
66 | | - # For production PyPI, leave unset (or set to empty string). |
67 | | - TWINE_REPOSITORY_URL: ${{ vars.PYPI_REPOSITORY_URL }} |
68 | | - run: | |
69 | | - python -m twine upload --disable-progress-bar --non-interactive dist/* |
| 87 | + uses: pypa/gh-action-pypi-publish@release/v1 |
70 | 88 |
|
| 89 | + release: |
| 90 | + needs: [build, publish] |
| 91 | + runs-on: ubuntu-22.04 |
| 92 | + permissions: |
| 93 | + # `gh release` requires write permission on repo contents |
| 94 | + contents: write |
| 95 | + steps: |
| 96 | + - name: Download build artifacts |
| 97 | + uses: actions/download-artifact@v4 |
| 98 | + with: |
| 99 | + name: dist |
| 100 | + path: dist/ |
71 | 101 | - name: Release to GitHub |
72 | 102 | env: |
73 | 103 | GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }} |
74 | | - TAG: ${{ steps.version.outputs.tag }} |
75 | | - TITLE: ${{ steps.version.outputs.tag }} |
| 104 | + TAG: ${{ needs.build.outputs.tag }} |
| 105 | + TITLE: ${{ needs.build.outputs.tag }} |
76 | 106 | NOTES: | |
77 | | - [Changelog](https://anymail.dev/en/stable/changelog/#${{ steps.version.outputs.anchor }}) |
| 107 | + [Changelog](https://anymail.dev/en/stable/changelog/#${{ needs.build.outputs.anchor }}) |
78 | 108 | run: | |
79 | 109 | if ! gh release edit "$TAG" --verify-tag --target "$GITHUB_SHA" --title "$TITLE" --notes "$NOTES"; then |
80 | 110 | gh release create "$TAG" --verify-tag --target "$GITHUB_SHA" --title "$TITLE" --notes "$NOTES" |
|
0 commit comments