-
-
Notifications
You must be signed in to change notification settings - Fork 293
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
base: master
Are you sure you want to change the base?
Conversation
5525de6
to
874600a
Compare
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 |
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.
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.
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.
@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! ❤️
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.
Ok if it's intentional then sounds good. Just one further question: is brew_dumper
still outputting true
correct with these changes?
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.
@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:) |
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.
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.
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.
@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.
874600a
to
0dfc121
Compare
brew "postgresql@16", | ||
postinstall: "${HOMEBREW_PREFIX}/opt/postgresql@16/bin/postgres -D ${HOMEBREW_PREFIX}/var/postgresql@16" |
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.
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.
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'm very excited for this ❤️
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. requirealways
to restart every time and otherwise just restart on an install or upgrade of a formula.