Sha256: 8ce914ef8096f2f789298b1193a54009c9612acca5a686bf955e3071f488815c
Contents?: true
Size: 1.25 KB
Versions: 2
Compression:
Stored size: 1.25 KB
Contents
require "spec_helper" require "hamster/list" require "concurrent/atomics" describe Hamster::List do it "ensures each node of a lazy list will only be realized on ONE thread, even when accessed by multiple threads" do counter = Concurrent::AtomicReference.new(0) list = (1..10000).to_list.map { |x| counter.update { |count| count + 1 }; x * 2 } threads = 10.times.collect do Thread.new do node = list node = node.tail until node.empty? end end threads.each(&:join) counter.get.should == 10000 list.sum.should == 100010000 end it "doesn't go into an infinite loop if lazy list block raises an exception" do list = (1..10).to_list.map { raise "Oops!" } threads = 10.times.collect do Thread.new do -> { list.head }.should raise_error(RuntimeError) end end threads.each(&:join) end it "doesn't give horrendously bad performance if thread realizing the list sleeps" do start = Time.now list = (1..100).to_list.map { |x| sleep(0.001); x * 2 } threads = 10.times.collect do Thread.new do node = list node = node.tail until node.empty? end end threads.each(&:join) elapsed = Time.now - start elapsed.should_not > 0.3 end end
Version data entries
2 entries across 2 versions & 2 rubygems
Version | Path |
---|---|
files.com-1.0.55 | docs/vendor/bundle/ruby/2.5.0/gems/hamster-3.0.0/spec/lib/hamster/list/multithreading_spec.rb |
hamster-3.0.0 | spec/lib/hamster/list/multithreading_spec.rb |