Skip to content

Commit

Permalink
Fix usage of Thread.handle_interrupt in MonitorMixin#mon_synchronize
Browse files Browse the repository at this point in the history
  • Loading branch information
eregon committed Mar 27, 2021
1 parent cc79c2f commit d17861b
Showing 1 changed file with 30 additions and 0 deletions.
30 changes: 30 additions & 0 deletions library/monitor/synchronize_spec.rb
Original file line number Diff line number Diff line change
@@ -0,0 +1,30 @@
require_relative '../../spec_helper'
require 'monitor'

describe "Monitor#synchronize" do
it "unlocks after return, even if it was interrupted by Thread#raise" do
exc_class = Class.new(RuntimeError)

monitor = Monitor.new
10.times do
locked = false

thread = Thread.new do
begin
monitor.synchronize do
locked = true
# Do not wait here, we are trying to interrupt the ensure part of #synchronize
end
sleep # wait for exception if it did not happen yet
rescue exc_class
monitor.should_not.mon_locked?
:ok
end
end

Thread.pass until locked
thread.raise exc_class, "interrupt"
thread.value.should == :ok
end
end
end

0 comments on commit d17861b

Please sign in to comment.