Skip to content

Commit

Permalink
Do not continue doing things after Ctrl+C
Browse files Browse the repository at this point in the history
Call Kernel.exit! 1 to force an immediate error-exit
if the operator uses Ctrl+C to prevent performing post-hook steps.

Signed-off-by: Marc A. Paradise <[email protected]>
  • Loading branch information
marcparadise committed Oct 15, 2021
1 parent e044314 commit 2c7b3b7
Show file tree
Hide file tree
Showing 2 changed files with 9 additions and 5 deletions.
2 changes: 1 addition & 1 deletion lib/omnibus-ctl.rb
Original file line number Diff line number Diff line change
Expand Up @@ -321,7 +321,7 @@ def scary_cleanse_warning(*args)
sleep 60
rescue Interrupt
log ""
exit 0
Kernel.exit 1
end
end
end
Expand Down
12 changes: 8 additions & 4 deletions spec/omnibus-ctl_spec.rb
Original file line number Diff line number Diff line change
Expand Up @@ -676,19 +676,17 @@ def ctl_output

describe "cleanse" do
before(:each) do
# this is potentially destructive if run on a live system,
# not to mention loaded with sleeps - skip it.
# No-op everything cleanup_procs_and_nuke wants to do, it's destructive
# (and slow/sleep-laden):
allow(@ctl).to receive("cleanup_procs_and_nuke").and_return 0
end

it "should invoke the cleanse_post_hook" do
# No-op everything cleanup_procs_and_nuke wants to do, it's destructive:
expect(@ctl).to receive("command_post_hook")
@ctl.run(%w{cleanse yes})
end

it "should invoke the scary_cleanse_warning" do
# No-op everything cleanup_procs_and_nuke wants to do, it's destructive:
expect(@ctl).to receive("scary_cleanse_warning")
@ctl.run(%w{cleanse yes})
end
Expand Down Expand Up @@ -742,6 +740,12 @@ def ctl_output
@ctl.scary_cleanse_warning("cleanse")
expect(ctl_output).not_to match(/--with-external/)
end

it "will hard-stop when the operator uses Ctrl+C to exit" do
allow(@ctl).to receive(:sleep).and_raise(Interrupt)
expect(Kernel).to receive(:exit).with(1)
@ctl.scary_cleanse_warning("cleanse")
end
end

context "cleanse_post_hook" do
Expand Down

0 comments on commit 2c7b3b7

Please sign in to comment.