Skip to content
This repository has been archived by the owner on Jul 17, 2024. It is now read-only.

chore: Create release workflow #46

Merged
merged 2 commits into from
May 13, 2024
Merged

chore: Create release workflow #46

merged 2 commits into from
May 13, 2024

Conversation

Christopher-Chianelli
Copy link
Collaborator

The workflow cannot be tested in full until 1.10 is out (since 1.9.0 is missing classes we use), but I tested on my own repo (replacing ref: v${{ github.event.inputs.version }} with ref: main).

Due to the particularities of GitHub, a manual action cannot be run unless it has a file in the main branch, but once it has a file on the main branch, you can run the action using a different branch.

@Christopher-Chianelli
Copy link
Collaborator Author

(Will add the PyPI action when we are ready to publish, since once a package on PyPI, it is impossible to retract it, and we don't want to accidentally publish it when testing the rest of the workflow).

@triceo
Copy link
Contributor

triceo commented May 6, 2024

@Christopher-Chianelli There is no staging workflow? That's unfortunate - because occasionally releases fail and it is so much easier to just delete an artifact from staging and restart the entire release, as opposed to writing CI that can restart itself from a particular point in the release.

@Christopher-Chianelli
Copy link
Collaborator Author

@triceo See pypi/warehouse#726, which would be a proper "staging" workflow. Currently, the "staging" workflow is to upload to test.pypi, which is another public index and verify the README.md renders correctly. What other companies do is upload the package to their own "staging" server.

@triceo
Copy link
Contributor

triceo commented May 6, 2024

@Christopher-Chianelli Does JReleaser support any of that? If not, then arguably it doesn't much matter what we choose.

@Christopher-Chianelli
Copy link
Collaborator Author

@triceo JReleaser does not explicitly support a "publish to PyPI" workflow. But it can attach the built wheel to the GitHub release. https://github.com/marketplace/actions/pypi-publish is what will be used to publish the package to PyPI.

Copy link
Contributor

@triceo triceo left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Good with comments.
Let's see how it works in practice.

jreleaser.yml Outdated Show resolved Hide resolved
.github/workflows/release.yml Outdated Show resolved Hide resolved
.github/workflows/release-pr-body.md Outdated Show resolved Hide resolved
@Christopher-Chianelli Christopher-Chianelli merged commit d5d0f42 into TimefoldAI:main May 13, 2024
3 checks passed
@triceo triceo deleted the release-workflow branch May 13, 2024 15:07
@aalmiray
Copy link

@Christopher-Chianelli happy to help figuring out what's needed from JReleaser's side to publish to PyPI as we do with other targets 😄

@Christopher-Chianelli
Copy link
Collaborator Author

@aalmiray Currently, we use https://github.com/pypa/gh-action-pypi-publish to publish to PyPI.

The documentation of the current PyPI API is available at https://peps.python.org/pep-0694/#status-quo.
Only the "Status Quo" section in relevant, since the rest of the PEP is a proposal on a new upload API still in draft.

How twine (the package uploader the action uses) uploads a package is

https://github.com/pypa/twine/blob/6fbf880ee60915cf1666348c4bdd78a10415f2ac/twine/repository.py#L129-L200

Ideally, a "PyPI publish" should:

Optional/nice to have:

Sign up for free to subscribe to this conversation on GitHub. Already have an account? Sign in.
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

3 participants