From e0a7e5e13141a06103673b9d4ff21ca864ec38f9 Mon Sep 17 00:00:00 2001 From: Nobuyoshi Nakada Date: Sun, 24 Jul 2022 16:35:38 +0900 Subject: Kill bundled gem tests when interrupted --- tool/test-bundled-gems.rb | 12 ++++++++++-- 1 file changed, 10 insertions(+), 2 deletions(-) (limited to 'tool/test-bundled-gems.rb') diff --git a/tool/test-bundled-gems.rb b/tool/test-bundled-gems.rb index 6312e1872d..1bdf2fa95a 100644 --- a/tool/test-bundled-gems.rb +++ b/tool/test-bundled-gems.rb @@ -71,15 +71,23 @@ File.foreach("#{gem_dir}/bundled_gems") do |line| break Timeout.timeout(sec) {Process.wait(pid)} rescue Timeout::Error end + rescue Interrupt + exit_code = Signal.list["INT"] + Process.kill("-KILL", pid) + Process.wait(pid) + break end unless $?.success? - puts "Tests failed with exit code #{$?.exitstatus}" + + puts "Tests failed " + + ($?.signaled? ? "by SIG#{Signal.signame($?.termsig)}" : + "with exit code #{$?.exitstatus}") if allowed_failures.include?(gem) puts "Ignoring test failures for #{gem} due to \$TEST_BUNDLED_GEMS_ALLOW_FAILURES" else failed << gem - exit_code = $?.exitstatus + exit_code = $?.exitstatus if $?.exitstatus end end print "##[endgroup]\n" if github_actions -- cgit v1.2.1