mirror of
https://github.com/ruby/ruby.git
synced 2022-11-09 12:17:21 -05:00
3f113219df
r64918 and r64988 should not be kept forever. git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/trunk@64992 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
40 lines
1.1 KiB
Ruby
40 lines
1.1 KiB
Ruby
require_relative '../../spec_helper'
|
|
require_relative 'fixtures/classes'
|
|
|
|
describe "ThreadGroup#add" do
|
|
before :each do
|
|
@chan1,@chan2 = Channel.new,Channel.new
|
|
@thread = Thread.new { @chan1 << :go; @chan2.receive }
|
|
@chan1.receive
|
|
end
|
|
|
|
after :each do
|
|
@chan2 << :done
|
|
@thread.join
|
|
end
|
|
|
|
# This spec randomly kills mspec worker like: https://ci.appveyor.com/project/ruby/ruby/build/9806/job/37tx2atojy96227m
|
|
# TODO: Investigate the cause or at least print helpful logs, and remove this `platform_is_not` guard.
|
|
platform_is_not :mingw do
|
|
it "adds the given thread to a group and returns self" do
|
|
@thread.group.should_not == nil
|
|
|
|
tg = ThreadGroup.new
|
|
tg.add(@thread).should == tg
|
|
@thread.group.should == tg
|
|
tg.list.include?(@thread).should == true
|
|
end
|
|
|
|
it "removes itself from any other threadgroup" do
|
|
tg1 = ThreadGroup.new
|
|
tg2 = ThreadGroup.new
|
|
|
|
tg1.add(@thread)
|
|
@thread.group.should == tg1
|
|
tg2.add(@thread)
|
|
@thread.group.should == tg2
|
|
tg2.list.include?(@thread).should == true
|
|
tg1.list.include?(@thread).should == false
|
|
end
|
|
end
|
|
end
|