mirror of
https://github.com/pypa/gh-action-pypi-publish
synced 2024-11-30 21:22:28 +08:00
Compare commits
9 Commits
61da13deb5
...
15c56dba36
Author | SHA1 | Date | |
---|---|---|---|
|
15c56dba36 | ||
|
fe8d1484ba | ||
|
1f5d4ec244 | ||
|
fec2f0c0ce | ||
|
a8b73a6d88 | ||
|
9b4dfb0c84 | ||
|
0a87186d5f | ||
|
dfcfeca43e | ||
|
0d02f372c3 |
@ -279,7 +279,7 @@ are released under the [BSD 3-clause license](LICENSE.md).
|
|||||||
|
|
||||||
|
|
||||||
[🧪 GitHub Actions CI/CD workflow tests badge]:
|
[🧪 GitHub Actions CI/CD workflow tests badge]:
|
||||||
https://github.com/pypa/gh-action-pypi-publish/actions/workflows/self-smoke-test-action.yml/badge.svg?branch=unstable%2Fv1&event=push
|
https://github.com/pypa/gh-action-pypi-publish/actions/workflows/build-and-push-docker-image.yml/badge.svg?branch=unstable%2Fv1&event=push
|
||||||
[GHA workflow runs list]:
|
[GHA workflow runs list]:
|
||||||
https://github.com/pypa/gh-action-pypi-publish/actions/workflows/self-smoke-test-action.yml?query=branch%3Aunstable%2Fv1
|
https://github.com/pypa/gh-action-pypi-publish/actions/workflows/self-smoke-test-action.yml?query=branch%3Aunstable%2Fv1
|
||||||
|
|
||||||
|
36
action.yml
36
action.yml
@ -130,24 +130,44 @@ runs:
|
|||||||
PR_REF: ${{ github.event.pull_request.head.ref }}
|
PR_REF: ${{ github.event.pull_request.head.ref }}
|
||||||
PR_REPO: ${{ github.event.pull_request.head.repo.full_name }}
|
PR_REPO: ${{ github.event.pull_request.head.repo.full_name }}
|
||||||
PR_REPO_ID: ${{ github.event.pull_request.base.repo.id }}
|
PR_REPO_ID: ${{ github.event.pull_request.base.repo.id }}
|
||||||
- name: Check out action repo
|
- name: Discover pre-installed Python
|
||||||
uses: actions/checkout@v4
|
id: pre-installed-python
|
||||||
|
run: |
|
||||||
|
# 🔎 Discover pre-installed Python
|
||||||
|
echo "python-path=$(command -v python3 || :)" | tee -a "${GITHUB_OUTPUT}"
|
||||||
|
shell: bash
|
||||||
|
- name: Install Python 3
|
||||||
|
if: steps.pre-installed-python.outputs.python-path == ''
|
||||||
|
id: new-python
|
||||||
|
uses: actions/setup-python@v5
|
||||||
with:
|
with:
|
||||||
path: action-repo
|
python-version: 3.x
|
||||||
ref: ${{ steps.set-repo-and-ref.outputs.ref }}
|
|
||||||
repository: ${{ steps.set-repo-and-ref.outputs.repo }}
|
|
||||||
- name: Create Docker container action
|
- name: Create Docker container action
|
||||||
run: |
|
run: |
|
||||||
# Create Docker container action
|
# Create Docker container action
|
||||||
python create-docker-action.py
|
${{
|
||||||
|
steps.pre-installed-python.outputs.python-path == ''
|
||||||
|
&& steps.new-python.outputs.python-path
|
||||||
|
|| steps.pre-installed-python.outputs.python-path
|
||||||
|
}} '${{ github.action_path }}/create-docker-action.py'
|
||||||
env:
|
env:
|
||||||
REF: ${{ steps.set-repo-and-ref.outputs.ref }}
|
REF: ${{ steps.set-repo-and-ref.outputs.ref }}
|
||||||
REPO: ${{ steps.set-repo-and-ref.outputs.repo }}
|
REPO: ${{ steps.set-repo-and-ref.outputs.repo }}
|
||||||
REPO_ID: ${{ steps.set-repo-and-ref.outputs.repo-id }}
|
REPO_ID: ${{ steps.set-repo-and-ref.outputs.repo-id }}
|
||||||
shell: bash
|
shell: bash
|
||||||
working-directory: action-repo
|
|
||||||
- name: Run Docker container
|
- name: Run Docker container
|
||||||
uses: ./action-repo/.github/actions/run-docker-container
|
# The generated trampoline action must exist in the allowlisted
|
||||||
|
# runner-defined working directory so it can be referenced by the
|
||||||
|
# relative path starting with `./`.
|
||||||
|
#
|
||||||
|
# This mutates the end-user's workspace slightly but uses a path
|
||||||
|
# that is unlikely to clash with somebody else's use.
|
||||||
|
#
|
||||||
|
# We cannot use randomized paths because the composite action
|
||||||
|
# syntax does not allow accessing variables in `uses:`. This
|
||||||
|
# means that we end up having to hardcode this path both here and
|
||||||
|
# in `create-docker-action.py`.
|
||||||
|
uses: ./.github/.tmp/.generated-actions/run-pypi-publish-in-docker-container
|
||||||
with:
|
with:
|
||||||
user: ${{ inputs.user }}
|
user: ${{ inputs.user }}
|
||||||
password: ${{ inputs.password }}
|
password: ${{ inputs.password }}
|
||||||
|
@ -54,6 +54,7 @@ def debug(msg: str):
|
|||||||
def collect_dists(packages_dir: Path) -> list[Path]:
|
def collect_dists(packages_dir: Path) -> list[Path]:
|
||||||
# Collect all sdists and wheels.
|
# Collect all sdists and wheels.
|
||||||
dist_paths = [sdist.resolve() for sdist in packages_dir.glob('*.tar.gz')]
|
dist_paths = [sdist.resolve() for sdist in packages_dir.glob('*.tar.gz')]
|
||||||
|
dist_paths.extend(sdist.resolve() for sdist in packages_dir.glob('*.zip'))
|
||||||
dist_paths.extend(whl.resolve() for whl in packages_dir.glob('*.whl'))
|
dist_paths.extend(whl.resolve() for whl in packages_dir.glob('*.whl'))
|
||||||
|
|
||||||
# Make sure everything that looks like a dist actually is one.
|
# Make sure everything that looks like a dist actually is one.
|
||||||
|
@ -10,10 +10,12 @@ REPO = os.environ['REPO']
|
|||||||
REPO_ID = os.environ['REPO_ID']
|
REPO_ID = os.environ['REPO_ID']
|
||||||
REPO_ID_GH_ACTION = '178055147'
|
REPO_ID_GH_ACTION = '178055147'
|
||||||
|
|
||||||
|
ACTION_SHELL_CHECKOUT_PATH = pathlib.Path(__file__).parent.resolve()
|
||||||
|
|
||||||
|
|
||||||
def set_image(ref: str, repo: str, repo_id: str) -> str:
|
def set_image(ref: str, repo: str, repo_id: str) -> str:
|
||||||
if repo_id == REPO_ID_GH_ACTION:
|
if repo_id == REPO_ID_GH_ACTION:
|
||||||
return '../../../Dockerfile'
|
return str(ACTION_SHELL_CHECKOUT_PATH / 'Dockerfile')
|
||||||
docker_ref = ref.replace('/', '-')
|
docker_ref = ref.replace('/', '-')
|
||||||
return f'docker://ghcr.io/{repo}:{docker_ref}'
|
return f'docker://ghcr.io/{repo}:{docker_ref}'
|
||||||
|
|
||||||
@ -70,6 +72,20 @@ action = {
|
|||||||
},
|
},
|
||||||
}
|
}
|
||||||
|
|
||||||
action_path = pathlib.Path('.github/actions/run-docker-container/action.yml')
|
# The generated trampoline action must exist in the allowlisted
|
||||||
|
# runner-defined working directory so it can be referenced by the
|
||||||
|
# relative path starting with `./`.
|
||||||
|
#
|
||||||
|
# This mutates the end-user's workspace slightly but uses a path
|
||||||
|
# that is unlikely to clash with somebody else's use.
|
||||||
|
#
|
||||||
|
# We cannot use randomized paths because the composite action
|
||||||
|
# syntax does not allow accessing variables in `uses:`. This
|
||||||
|
# means that we end up having to hardcode this path both here and
|
||||||
|
# in `action.yml`.
|
||||||
|
action_path = pathlib.Path(
|
||||||
|
'.github/.tmp/.generated-actions/'
|
||||||
|
'run-pypi-publish-in-docker-container/action.yml',
|
||||||
|
)
|
||||||
action_path.parent.mkdir(parents=True, exist_ok=True)
|
action_path.parent.mkdir(parents=True, exist_ok=True)
|
||||||
action_path.write_text(json.dumps(action, ensure_ascii=False), encoding='utf-8')
|
action_path.write_text(json.dumps(action, ensure_ascii=False), encoding='utf-8')
|
||||||
|
@ -10,7 +10,7 @@ id ~= 1.0
|
|||||||
requests
|
requests
|
||||||
|
|
||||||
# NOTE: Used to generate attestations.
|
# NOTE: Used to generate attestations.
|
||||||
pypi-attestations ~= 0.0.13
|
pypi-attestations ~= 0.0.15
|
||||||
sigstore ~= 3.5.1
|
sigstore ~= 3.5.1
|
||||||
|
|
||||||
# NOTE: Used to detect the PyPI package name from the distribution files
|
# NOTE: Used to detect the PyPI package name from the distribution files
|
||||||
|
@ -93,7 +93,7 @@ pyjwt==2.8.0
|
|||||||
# via sigstore
|
# via sigstore
|
||||||
pyopenssl==24.1.0
|
pyopenssl==24.1.0
|
||||||
# via sigstore
|
# via sigstore
|
||||||
pypi-attestations==0.0.13
|
pypi-attestations==0.0.15
|
||||||
# via -r runtime.in
|
# via -r runtime.in
|
||||||
python-dateutil==2.9.0.post0
|
python-dateutil==2.9.0.post0
|
||||||
# via betterproto
|
# via betterproto
|
||||||
|
Loading…
Reference in New Issue
Block a user