1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99
|
require_relative 'executor_service_shared'
module Concurrent
RSpec.describe SimpleExecutorService do
subject { SimpleExecutorService.new }
it_should_behave_like :executor_service
context '#post' do
subject { SimpleExecutorService.new }
it 'creates a new thread for a call without arguments' do
thread = in_thread{ nil }
expect(Thread).to receive(:new).with(no_args()).and_return(thread)
expect(Concurrent.global_fast_executor).not_to receive(:post).with(any_args())
subject.post{ nil }
end
it 'executes a call without arguments' do
latch = CountDownLatch.new(1)
subject.post{ latch.count_down }
expect(latch.wait(1)).to be_truthy
end
it 'creates a new thread for a call with arguments' do
thread = in_thread{ nil }
expect(Thread).to receive(:new).with(1,2,3).and_return(thread)
expect(Concurrent.global_fast_executor).not_to receive(:post).with(any_args())
subject.post(1,2,3){ nil }
end
it 'executes a call with one argument' do
latch = CountDownLatch.new(3)
subject.post(3){|count| count.times{ latch.count_down } }
expect(latch.wait(1)).to be_truthy
end
it 'executes a call with multiple arguments' do
latch = CountDownLatch.new(10)
subject.post(1,2,3,4){|*count| count.reduce(:+).times{ latch.count_down } }
expect(latch.wait(1)).to be_truthy
end
it 'aliases #<<' do
thread = in_thread{ nil }
expect(Thread).to receive(:new).with(no_args()).and_return(thread)
expect(Concurrent.global_fast_executor).not_to receive(:post).with(any_args())
subject << proc{ nil }
end
end
context 'SimpleExecutorService.post' do
subject { SimpleExecutorService }
it 'creates a new thread for a call without arguments' do
thread = in_thread{ nil }
expect(Thread).to receive(:new).with(no_args()).and_return(thread)
expect(Concurrent.global_fast_executor).not_to receive(:post).with(any_args())
subject.post{ nil }
end
it 'executes a call without arguments' do
latch = CountDownLatch.new(1)
subject.post{ latch.count_down }
expect(latch.wait(1)).to be_truthy
end
it 'creates a new thread for a call with arguments' do
thread = in_thread{ nil }
expect(Thread).to receive(:new).with(1,2,3).and_return(thread)
expect(Concurrent.global_fast_executor).not_to receive(:post).with(any_args())
subject.post(1,2,3){ nil }
end
it 'executes a call with one argument' do
latch = CountDownLatch.new(3)
subject.post(3){|count| count.times{ latch.count_down } }
expect(latch.wait(1)).to be_truthy
end
it 'executes a call with multiple arguments' do
latch = CountDownLatch.new(10)
subject.post(1,2,3,4){|*count| count.reduce(:+).times{ latch.count_down } }
expect(latch.wait(1)).to be_truthy
end
it 'aliases #<<' do
thread = in_thread{ nil }
expect(Thread).to receive(:new).with(no_args()).and_return(thread)
expect(Concurrent.global_fast_executor).not_to receive(:post).with(any_args())
subject << proc{ nil }
end
end
end
end
|