mirror of
https://github.com/fish-shell/fish-shell
synced 2025-01-15 14:34:05 +00:00
55 lines
2.3 KiB
Markdown
55 lines
2.3 KiB
Markdown
|
# Building macOS Artifacts
|
||
|
|
||
|
This describes how to build macOS artifacts as part of a release. These artifacts are uploaded to the GitHub release page, where they are discovered by the web site build script.
|
||
|
|
||
|
Artifacts may be built locally or in CI. Using CI is preferred.
|
||
|
|
||
|
> **Note**
|
||
|
> Only fish-shell administrations may create releases. Released macOS packages require code signing and notarization via private Apple developer keys, which are owned by @ridiculous_fish. These keys are stored in GitHub secrets.
|
||
|
|
||
|
## Building in CI (GitHub Actions)
|
||
|
|
||
|
macOS packages may be built in CI through a GitHub workflow. This requires a fish-shell administrator as it requires invoking secret code signing keys.
|
||
|
|
||
|
Steps:
|
||
|
|
||
|
1. Go to https://github.com/fish-shell/fish-shell/actions
|
||
|
2. On the left side, click on the "macOS build and codesign" Action.
|
||
|
3. On the right, click on the "Run workflow" button, select the branch or tag, and click Run Workflow.
|
||
|
4. **Reload the page**. This is necessary because the workflow will not appear until the page is reloaded.
|
||
|
5. Click on the new workflow. It should be in a Waiting state.
|
||
|
6. Click on Review Deployments, and approve and start the "deployment."
|
||
|
7. Once the workflow completes, expand the `actions/upload-artifact@v4` step in the logs. This should have an "Artifact download URL" - click it and download!
|
||
|
|
||
|
## Building locally (no code signing)
|
||
|
|
||
|
To build locally without notarizing and code signing, use the `build_tools/make_pkg.sh` script:
|
||
|
|
||
|
```
|
||
|
> ./build_tools/make_pkg.sh
|
||
|
```
|
||
|
|
||
|
Packages will be placed in `~/fish_built` by default.
|
||
|
|
||
|
Note these packages will result in loud warnings or errors when others try to install them, because of the lack of code signing.
|
||
|
|
||
|
## Building locally with code signing and notarization
|
||
|
|
||
|
You will need the following:
|
||
|
|
||
|
- The ".p12" certificate files for both "Developer ID Application" and "Developer ID Installer".
|
||
|
- (These can be generated via Export Certificate in Xcode)
|
||
|
- The password for these files (by convention, the same password is used for both).
|
||
|
- The JSON file generated via `rcodesign encode-app-store-connect-api-key`.
|
||
|
|
||
|
An example run:
|
||
|
|
||
|
```
|
||
|
> ./build_tools/make_pkg.sh -s \
|
||
|
-f fish-developer-id-application.p12 \
|
||
|
-i fish-developer-id-installer.p12 \
|
||
|
-p "$NOTARIZE_PASSWORD" \
|
||
|
-n \
|
||
|
-j notarize-data.json
|
||
|
```
|