Sha256: bb3c023067f7bd8aefbf93af7d3d6c55b2451b5c497d337149985b95eb511c60

Contents?: true

Size: 1.51 KB

Versions: 4

Compression:

Stored size: 1.51 KB

Contents

require File.expand_path('../spec_helper', __FILE__)
require 'tempfile'
require 'fcntl'

describe Cool.io::AsyncWatcher do

  it "does not signal on spurious wakeups" do
    aw = Cool.io::AsyncWatcher.new
    tmp = Tempfile.new('coolio_async_watcher_test')
    nr_fork = 2 # must be at least two for spurious wakeups

    # We have aetter chance of failing if this overflows the pipe buffer
    # which POSIX requires >= 512 bytes, Linux 2.6 uses 4096 bytes
    nr_signal = 4096 * 4

    append = File.open(tmp.path, "ab")
    append.sync = true
    rd, wr = ::IO.pipe

    aw.on_signal { append.syswrite("#$$\n") }
    children = nr_fork.times.map do
      fork do
        trap(:TERM) { exit!(0) }
        rloop = Cool.io::Loop.default
        aw.attach(rloop)
        wr.write '.' # signal to master that we're ready
        rloop.run
        exit!(1) # should not get here
      end
    end

    # ensure children are ready
    nr_fork.times { rd.sysread(1).should == '.' }

    # send our signals
    nr_signal.times { aw.signal }

    # wait for the pipe buffer to be consumed by the children
    sleep 1 while tmp.stat.ctime >= (Time.now - 4)

    children.each do |pid|
      Process.kill(:TERM, pid)
      _, status = Process.waitpid2(pid)
      status.exitstatus.should == 0
    end

    # we should've written a line for every signal we sent
    lines = tmp.readlines
    lines.size.should == nr_signal

    # theoretically a bad kernel scheduler could give us fewer...
    lines.sort.uniq.size.should == nr_fork

    tmp.close!
  end

end

Version data entries

4 entries across 4 versions & 1 rubygems

Version Path
cool.io-1.1.1 spec/async_watcher_spec.rb
cool.io-1.1.0 spec/async_watcher_spec.rb
cool.io-1.0.0 spec/async_watcher_spec.rb
cool.io-0.9.0 spec/async_watcher_spec.rb