Skip to content

Commit

Permalink
Merge pull request ckan#8559 from ckan/fix-push-to-pypi
Browse files Browse the repository at this point in the history
Fixes in the PyPI publish workflow
  • Loading branch information
kowh-ai authored Dec 5, 2024
2 parents aedf459 + 170837e commit e34aac5
Show file tree
Hide file tree
Showing 2 changed files with 64 additions and 30 deletions.
38 changes: 8 additions & 30 deletions .github/workflows/publish-pypi.yml
Original file line number Diff line number Diff line change
@@ -1,12 +1,15 @@
name: Publish to PyPI and TestPyPI
name: Publish to PyPI

on: push
# Publish to PyPI when a tag is pushed
on:
push:
tags:
- 'ckan-**'

jobs:
build:
name: Build distribution
runs-on: ubuntu-latest

steps:
- uses: actions/checkout@v4
- name: Set up Python
Expand All @@ -22,15 +25,13 @@ jobs:
- name: Build a binary wheel and a source tarball
run: python3 -m build
- name: Store the distribution packages
uses: actions/upload-artifact@v3
uses: actions/upload-artifact@v4
with:
name: python-package-distributions
path: dist/

publish-to-pypi:
name: Publish Python distribution on PyPI
# Publish to PyPI when pushing a tag
if: startsWith(github.ref, 'refs/tags/')
needs:
- build
runs-on: ubuntu-latest
Expand All @@ -41,32 +42,9 @@ jobs:
id-token: write
steps:
- name: Download all the dists
uses: actions/download-artifact@v3
uses: actions/download-artifact@v4
with:
name: python-package-distributions
path: dist/
- name: Publish distribution to PyPI
uses: pypa/gh-action-pypi-publish@release/v1

publish-to-testpypi:
name: Publish Python distribution on TestPyPI
# Publish to Test PyPI when a pull request is merged
if: github.event_name == 'pull_request' && github.event.action == 'closed' && github.event.pull_request.merged == true
needs:
- build
runs-on: ubuntu-latest
environment:
name: pypi
url: https://test.pypi.org/p/ckan
permissions:
id-token: write
steps:
- name: Download all the dists
uses: actions/download-artifact@v3
with:
name: python-package-distributions
path: dist/
- name: Publish distribution to PyPI
uses: pypa/gh-action-pypi-publish@release/v1
with:
repository-url: https://test.pypi.org/legacy/
56 changes: 56 additions & 0 deletions .github/workflows/publish-test-pypi.yml
Original file line number Diff line number Diff line change
@@ -0,0 +1,56 @@
name: Publish to TestPyPI

# Publish to Test PyPI when a pull request is merged to master
on:
push:
branches:
- 'master'

jobs:
build:
name: Build distribution
runs-on: ubuntu-latest
steps:
- uses: actions/checkout@v4
- name: Set up Python
uses: actions/setup-python@v5
with:
python-version: "3.9"
- name: Add timestamp to version number
run: |
TIMESTAMP=$(date +"%Y%m%d%H%M")
sed -E -i 's/__version__ = "(.*)"$/__version__ = "\1.post'$TIMESTAMP'"/' ckan/__init__.py
- name: Install pypa/build
run: >-
python3 -m
pip install
build
--user
- name: Build a binary wheel and a source tarball
run: python3 -m build
- name: Store the distribution packages
uses: actions/upload-artifact@v4
with:
name: python-package-distributions
path: dist/

publish-to-testpypi:
name: Publish Python distribution on TestPyPI
needs:
- build
runs-on: ubuntu-latest
environment:
name: test-pypi
url: https://test.pypi.org/p/ckan
permissions:
id-token: write
steps:
- name: Download all the dists
uses: actions/download-artifact@v4
with:
name: python-package-distributions
path: dist/
- name: Publish distribution to TestPyPI
uses: pypa/gh-action-pypi-publish@release/v1
with:
repository-url: https://test.pypi.org/legacy/

0 comments on commit e34aac5

Please sign in to comment.