summaryrefslogtreecommitdiff
path: root/test/fiber/test_timeout.rb
blob: 5493606be00ba32836946a0a2389abd62f49a1e8 (plain)
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
# frozen_string_literal: true
require 'test/unit'
require_relative 'scheduler'

require 'timeout'

class TestFiberTimeout < Test::Unit::TestCase
  def test_timeout_after
    error = nil

    thread = Thread.new do
      scheduler = Scheduler.new
      Fiber.set_scheduler scheduler

      Fiber.schedule do
        begin
          Timeout.timeout(0.001) do
            sleep(1)
          end
        rescue
          error = $!
        end
      end
    end

    thread.join

    assert_kind_of(Timeout::Error, error)
  end

  MESSAGE = "Hello World"

  def test_timeout_on_main_fiber
    message = nil

    thread = Thread.new do
      scheduler = Scheduler.new
      Fiber.set_scheduler scheduler

      assert_nil Fiber.current_scheduler

      Timeout.timeout(1) do
        message = MESSAGE
      end
    end

    thread.join

    assert_equal MESSAGE, message
  end
end