-
Notifications
You must be signed in to change notification settings - Fork 22
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Create DMGs for x64 and arm64 builds #135
Conversation
2c114f4
to
0f3746c
Compare
I brought the PR originally opened by @p-jackson to this repository, rebased it, solved conflicts, and tested it locally. I can build all three Mac binaries, but |
@@ -42,6 +42,7 @@ steps: | |||
.buildkite/commands/install-node-dependencies.sh | |||
node ./scripts/prepare-dev-build-version.mjs | |||
npm run make:macos-{{matrix}} | |||
npm run make:dmg-{{matrix}} |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Should it happen after we notarize the binary?
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Here's what the docs say:
Alternatively, you can put apps, kernel extensions, and other software in a container, like a disk image, and notarize the container. The notary service accepts disk images (UDIF format), signed flat installer packages, and ZIP archives. It processes nested containers as well, like packages inside a disk image.
Important: If you distribute your software via a custom third-party installer, you need two rounds of notarization. First you notarize the installer’s payload (everything the installer will install). You then package the notarized (and stapled, as described in Staple the ticket to your distribution) items into the installer and notarize it as you would any other executable. If you use a network installer, separately notarize both the installer and the items it downloads.
So, I think in our case, given we distribute both .app
and .dmg
, we'll want to notarize both. If we were only distributing the DMG, we could notarize just that and trust Apple's tooling will handle it.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I tried a local notarization of a DMG built from this branch, as of d538a17, and this diff worked:
--- a/fastlane/Fastfile
+++ b/fastlane/Fastfile
@@ -45,13 +45,20 @@ lane :set_up_signing do |_options|
end
desc 'Notarize the compiled binary'
-lane :notarize_binary do |_options|
+lane :notarize_binary do
Dir[File.join(BUILDS_FOLDER, '**', 'Studio.app')].each do |path|
notarize(
package: path,
api_key_path: APPLE_API_KEY_PATH
)
end
+ Dir[File.join(BUILDS_FOLDER, '**', 'Studio-*.dmg')].each do |path|
+ notarize(
+ bundle_id: APPLE_BUNDLE_IDENTIFIER,
+ package: path,
+ api_key_path: APPLE_API_KEY_PATH
+ )
+ end
end
desc 'Ship the binary to internal testers'
619784d
to
fcbc10a
Compare
The error I'm getting:
As @p-jackson explained under https://github.com/Automattic/local-environment/pull/266#issuecomment-2058532243, fs-xattrs couldn't load xattr.node file for arm64 and file for x64 was available there. During some debugging I tried today, it started working on my local. After reverting changes in the |
Worth noting, there is a newer version of the https://github.com/LinusU/fs-xattr/releases/tag/v0.4.0 Also,
|
filename_core: 'darwin-universal', | ||
extension: 'dmg', | ||
name: 'Mac Universal (DMG)' | ||
}, |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Glad the DRY from #117 turned out to be useful. I wasn't expecting us to add new files to upload, but there you go. Happy it was here.
I tried using a CLI tool for DMG, and it works on local for all cases. However, the Buildkite pipeline fails with:
It may be similar to create-dmg/create-dmg#72 |
806036f
to
569b579
Compare
I reported the initial issue under electron/forge#3604. |
e9a8df5
to
f8140f6
Compare
Gotta smile... the PR changes the DMG logic, and the Windows build fails 🙃 I've seen this error already in another app. The workaround there was to change the versioning style in // Usually, dev builds have major.minor.patch-dev.suffix .
//
// const devVersion = `${ packageJson.version.split( '-' )[ 0 ] }-dev.${ currentCommitShort }`;
//
// However, we're getting build failures (only in Windows, it seems) in parsing the last component separated by a '.'
// As such, let's try adding a '-' instead.
//
// See [redacted]
//
// Interesting, also, we seem to be getting the error only for commits that begin with letters, not numbers.
// See [redacted]
const devVersion = `${ packageJson.version.split( '-' )[ 0 ] }-dev-${ currentCommitShort }`; I find it odd that this issue was not in Studio before. @wojtekn maybe a dependency update introduced a bug here? |
Yes, this is caused by the Electron Forge upgrade to 7.4.0. I've merged it today and rebased this branch to see if it fixes DMG issue by the chance. There is an open issue for that (electron/packager#1714) and I think we will need to downgrade electron Forge to 7.3.1 until it's fixed. |
This will be solved in #201. |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
@fluiddot @wojtekn the missing background appears to be a known side-effect of using I tested the DMG on both Apple Silicon (M1 Max) and Intel. They both worked. @wojtekn assuming we are okay to iterate on the DMG UI, I think this would be good to merge? |
@mokagio I think the key is to make it work without |
As shared by Wojtek, it would be nice if we could solve the missing background and icon positioning. Not sure if we tried before but I created a draft PR using https://github.com/LinusU/node-appdmg which successfully created DMG files. |
* Use `appdmg` in `made-dmg` script * Do not install `create-dmg` in Buildkite * Rebuild specific node native modules * [TEST] Log native module rebuild * Conditionally rebuild `fs-xattr` before packaging DMG to fix dlopen issue (#321) * Install Rosetta on macOS Try to address https://buildkite.com/automattic/studio/builds/1543#01904ffb-8498-4d13-aa5a-e2b3c6dbb302 * Rebuild fs-xatrr after binary has been built, conditionally * Revert "Install Rosetta on macOS" This reverts commit 8a4cab7. * Address typos in Buildkite pipeline * Avoid verbose output when rebuilding `fs-xattr` --------- Co-authored-by: Gio Lodi <[email protected]>
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
LGTM 🎊 ! I confirmed that all DMG files work as expected for all macOS variants.
Related to https://github.com/Automattic/dotcom-forge/issues/6949
The PR was initially opened by @p-jackson : https://github.com/Automattic/local-environment/pull/266
Electron forge has a built in ability to create DMGs. But when I try and use it to create a DMG for the Intel build on my M1 mac there's an error.
I'm trying a different approach where I don't use electron forge, but instead invoke
electron-installer-dmg
directly, which is the package used under the hood by electron forge.Seems to do the trick, but I need
Proposed Changes
Depend directly onelectron-installer-dmg
create-dmg
CLI tool to create DMG filesmake:dmg-arm64
,make:dmg-x64
, andmake:dmg-universal
scripts to create DMGsTesting Instructions
I don't think it's possible to test this on buildkite now before merging. It's been restricted to only build from
trunk
, so I can't sneakily have it run other branches. But it is testable locally.arm64
npm install
npm run make:macos-arm64
npm run make:dmg-arm64
out/Studio-darwin-arm64.dmg
x64
npm install
npm run make:macos-x64
npm rebuild fs-xattr --cpu universal
npm run make:dmg-x64
out/Studio-darwin-x64.dmg
universal
npm install
npm run make:macos-universal
npm rebuild fs-xattr --cpu universal
npm run make:dmg-universal
out/Studio-darwin-universal.dmg
The same should work for all platforms:
arm64
,x64
anduniversal
.Pre-merge Checklist