Skip to content
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

Add postinstall support for brew and cask #1555

Open
wants to merge 1 commit into
base: master
Choose a base branch
from
Open

Conversation

MikeMcQuaid
Copy link
Member

This allows postinstall to be used to run a command after a formula or cask is installed.

While we're here, also adjust the restart_service behaviour to correctly match the comment i.e. require always to restart every time and otherwise just restart on an install or upgrade of a formula.

@MikeMcQuaid MikeMcQuaid force-pushed the postinstall branch 2 times, most recently from 5525de6 to 874600a Compare January 9, 2025 15:38
@MikeMcQuaid MikeMcQuaid marked this pull request as ready for review January 9, 2025 15:38
@MikeMcQuaid MikeMcQuaid requested review from Bo98 and carlocab January 9, 2025 15:39
Comment on lines -452 to +506
it "is true with {restart_service: true}" do
expect(described_class.new(formula, restart_service: true).restart_service_needed?).to be(true)
it "is false with {restart_service: true}" do
expect(described_class.new(formula, restart_service: true).restart_service_needed?).to be(false)
end
Copy link
Member

Choose a reason for hiding this comment

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

This seems like a breaking change? https://github.com/search?q=%2Fbrew.*restart_service%3A+true%2F+NOT+is%3Afork&type=code.

brew_dumper also outputs restart_service: true.

I checked where the comment originated from, and it seems like it was a typo and true was the always-mode: c97d044.

Copy link
Member Author

Choose a reason for hiding this comment

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

@Bo98 It's a behaviour change but not a breaking one. It'll still be run on installs/upgrades, just no longer unconditionally on every brew bundle run. restart_service: true will imply "on change" rather than "every time regardless of change". Also, if the service isn't running, it'll be started regardless.

Given we're doing this behaviour now for services, link and post install it feels like it makes more sense to be consistent here than hold onto previous behaviour.

Of course, if people loudly complain otherwise: we can switch it back.

Thanks for calling this out, though, it warranted further explanation! ❤️

Copy link
Member

Choose a reason for hiding this comment

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

Ok if it's intentional then sounds good. Just one further question: is brew_dumper still outputting true correct with these changes?

Copy link
Member Author

Choose a reason for hiding this comment

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

@Bo98 I've adjusted it to output :changed and updated the README accordingly, good idea.

return true unless changed?

puts "Running postinstall for #{@name}." if verbose
Bundle.system(@postinstall, verbose:)
Copy link
Member

Choose a reason for hiding this comment

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

Does this work with the README example where it's all one string rather than separate arguments? Bundle.system intentionally avoids shell execution so may need another method.

Copy link
Member Author

Choose a reason for hiding this comment

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

@Bo98 Yup, still works, that's what I tested locally.

This allows `postinstall` to be used to run a command after a formula
or cask is installed.

While we're here, also adjust the `restart_service` behaviour to
correctly match the comment i.e. require `always` to restart every
time and otherwise just restart on an install or upgrade of a formula.
Comment on lines +45 to +46
brew "postgresql@16",
postinstall: "${HOMEBREW_PREFIX}/opt/postgresql@16/bin/postgres -D ${HOMEBREW_PREFIX}/var/postgresql@16"
Copy link
Member

Choose a reason for hiding this comment

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

It might be nice to have postinstall run in the same environment as brew bundle exec so that the formula bin directory is in PATH, etc.

Copy link
Member

@colindean colindean left a comment

Choose a reason for hiding this comment

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

I'm very excited for this ❤️

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

Successfully merging this pull request may close these issues.

5 participants