MattHulse-eventmachine 0.0.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (156) hide show
  1. data/.gitignore +14 -0
  2. data/README +82 -0
  3. data/Rakefile +279 -0
  4. data/docs/COPYING +60 -0
  5. data/docs/ChangeLog +211 -0
  6. data/docs/DEFERRABLES +133 -0
  7. data/docs/EPOLL +141 -0
  8. data/docs/GNU +281 -0
  9. data/docs/INSTALL +13 -0
  10. data/docs/KEYBOARD +38 -0
  11. data/docs/LEGAL +25 -0
  12. data/docs/LIGHTWEIGHT_CONCURRENCY +70 -0
  13. data/docs/PURE_RUBY +75 -0
  14. data/docs/RELEASE_NOTES +94 -0
  15. data/docs/SMTP +2 -0
  16. data/docs/SPAWNED_PROCESSES +89 -0
  17. data/docs/TODO +8 -0
  18. data/eventmachine.gemspec +41 -0
  19. data/examples/ex_channel.rb +43 -0
  20. data/examples/ex_queue.rb +2 -0
  21. data/examples/helper.rb +2 -0
  22. data/ext/binder.cpp +125 -0
  23. data/ext/binder.h +46 -0
  24. data/ext/cmain.cpp +821 -0
  25. data/ext/cplusplus.cpp +202 -0
  26. data/ext/ed.cpp +1868 -0
  27. data/ext/ed.h +416 -0
  28. data/ext/em.cpp +2270 -0
  29. data/ext/em.h +228 -0
  30. data/ext/emwin.cpp +300 -0
  31. data/ext/emwin.h +94 -0
  32. data/ext/epoll.cpp +26 -0
  33. data/ext/epoll.h +25 -0
  34. data/ext/eventmachine.h +122 -0
  35. data/ext/eventmachine_cpp.h +96 -0
  36. data/ext/extconf.rb +138 -0
  37. data/ext/fastfilereader/extconf.rb +84 -0
  38. data/ext/fastfilereader/mapper.cpp +214 -0
  39. data/ext/fastfilereader/mapper.h +59 -0
  40. data/ext/fastfilereader/rubymain.cpp +127 -0
  41. data/ext/files.cpp +94 -0
  42. data/ext/files.h +65 -0
  43. data/ext/kb.cpp +81 -0
  44. data/ext/page.cpp +107 -0
  45. data/ext/page.h +51 -0
  46. data/ext/pipe.cpp +349 -0
  47. data/ext/project.h +147 -0
  48. data/ext/rubymain.cpp +1152 -0
  49. data/ext/sigs.cpp +89 -0
  50. data/ext/sigs.h +32 -0
  51. data/ext/ssl.cpp +460 -0
  52. data/ext/ssl.h +94 -0
  53. data/java/.classpath +8 -0
  54. data/java/.project +17 -0
  55. data/java/src/com/rubyeventmachine/Application.java +192 -0
  56. data/java/src/com/rubyeventmachine/Connection.java +74 -0
  57. data/java/src/com/rubyeventmachine/ConnectionFactory.java +37 -0
  58. data/java/src/com/rubyeventmachine/DefaultConnectionFactory.java +46 -0
  59. data/java/src/com/rubyeventmachine/EmReactor.java +557 -0
  60. data/java/src/com/rubyeventmachine/EmReactorException.java +40 -0
  61. data/java/src/com/rubyeventmachine/EventableChannel.java +69 -0
  62. data/java/src/com/rubyeventmachine/EventableDatagramChannel.java +189 -0
  63. data/java/src/com/rubyeventmachine/EventableSocketChannel.java +364 -0
  64. data/java/src/com/rubyeventmachine/PeriodicTimer.java +38 -0
  65. data/java/src/com/rubyeventmachine/Timer.java +54 -0
  66. data/java/src/com/rubyeventmachine/tests/ApplicationTest.java +108 -0
  67. data/java/src/com/rubyeventmachine/tests/ConnectTest.java +146 -0
  68. data/java/src/com/rubyeventmachine/tests/EMTest.java +80 -0
  69. data/java/src/com/rubyeventmachine/tests/TestDatagrams.java +53 -0
  70. data/java/src/com/rubyeventmachine/tests/TestServers.java +74 -0
  71. data/java/src/com/rubyeventmachine/tests/TestTimers.java +89 -0
  72. data/lib/em/buftok.rb +138 -0
  73. data/lib/em/callback.rb +26 -0
  74. data/lib/em/channel.rb +57 -0
  75. data/lib/em/connection.rb +564 -0
  76. data/lib/em/deferrable.rb +187 -0
  77. data/lib/em/file_watch.rb +54 -0
  78. data/lib/em/future.rb +61 -0
  79. data/lib/em/messages.rb +66 -0
  80. data/lib/em/process_watch.rb +44 -0
  81. data/lib/em/processes.rb +119 -0
  82. data/lib/em/protocols.rb +35 -0
  83. data/lib/em/protocols/header_and_content.rb +138 -0
  84. data/lib/em/protocols/httpclient.rb +263 -0
  85. data/lib/em/protocols/httpclient2.rb +582 -0
  86. data/lib/em/protocols/line_and_text.rb +126 -0
  87. data/lib/em/protocols/linetext2.rb +160 -0
  88. data/lib/em/protocols/memcache.rb +323 -0
  89. data/lib/em/protocols/object_protocol.rb +45 -0
  90. data/lib/em/protocols/postgres3.rb +247 -0
  91. data/lib/em/protocols/saslauth.rb +175 -0
  92. data/lib/em/protocols/smtpclient.rb +350 -0
  93. data/lib/em/protocols/smtpserver.rb +547 -0
  94. data/lib/em/protocols/stomp.rb +200 -0
  95. data/lib/em/protocols/tcptest.rb +53 -0
  96. data/lib/em/queue.rb +61 -0
  97. data/lib/em/spawnable.rb +85 -0
  98. data/lib/em/streamer.rb +130 -0
  99. data/lib/em/timers.rb +55 -0
  100. data/lib/em/version.rb +3 -0
  101. data/lib/eventmachine.rb +1698 -0
  102. data/lib/evma.rb +32 -0
  103. data/lib/evma/callback.rb +32 -0
  104. data/lib/evma/container.rb +75 -0
  105. data/lib/evma/factory.rb +77 -0
  106. data/lib/evma/protocol.rb +87 -0
  107. data/lib/evma/reactor.rb +48 -0
  108. data/lib/jeventmachine.rb +246 -0
  109. data/lib/pr_eventmachine.rb +1022 -0
  110. data/setup.rb +1585 -0
  111. data/tasks/cpp.rake +77 -0
  112. data/tasks/project.rake +79 -0
  113. data/tasks/tests.rake +193 -0
  114. data/tests/client.crt +31 -0
  115. data/tests/client.key +51 -0
  116. data/tests/test_attach.rb +126 -0
  117. data/tests/test_basic.rb +284 -0
  118. data/tests/test_channel.rb +63 -0
  119. data/tests/test_connection_count.rb +35 -0
  120. data/tests/test_defer.rb +47 -0
  121. data/tests/test_epoll.rb +160 -0
  122. data/tests/test_error_handler.rb +35 -0
  123. data/tests/test_errors.rb +82 -0
  124. data/tests/test_exc.rb +55 -0
  125. data/tests/test_file_watch.rb +49 -0
  126. data/tests/test_futures.rb +198 -0
  127. data/tests/test_handler_check.rb +37 -0
  128. data/tests/test_hc.rb +218 -0
  129. data/tests/test_httpclient.rb +218 -0
  130. data/tests/test_httpclient2.rb +153 -0
  131. data/tests/test_inactivity_timeout.rb +50 -0
  132. data/tests/test_kb.rb +60 -0
  133. data/tests/test_ltp.rb +182 -0
  134. data/tests/test_ltp2.rb +317 -0
  135. data/tests/test_next_tick.rb +133 -0
  136. data/tests/test_object_protocol.rb +37 -0
  137. data/tests/test_process_watch.rb +48 -0
  138. data/tests/test_processes.rb +128 -0
  139. data/tests/test_proxy_connection.rb +92 -0
  140. data/tests/test_pure.rb +125 -0
  141. data/tests/test_queue.rb +44 -0
  142. data/tests/test_running.rb +42 -0
  143. data/tests/test_sasl.rb +72 -0
  144. data/tests/test_send_file.rb +242 -0
  145. data/tests/test_servers.rb +76 -0
  146. data/tests/test_smtpclient.rb +83 -0
  147. data/tests/test_smtpserver.rb +85 -0
  148. data/tests/test_spawn.rb +322 -0
  149. data/tests/test_ssl_args.rb +68 -0
  150. data/tests/test_ssl_methods.rb +50 -0
  151. data/tests/test_ssl_verify.rb +82 -0
  152. data/tests/test_timers.rb +162 -0
  153. data/tests/test_ud.rb +36 -0
  154. data/tests/testem.rb +31 -0
  155. data/web/whatis +7 -0
  156. metadata +223 -0
@@ -0,0 +1,133 @@
1
+ # $Id$
2
+ #
3
+ # Author:: Francis Cianfrocca (gmail: blackhedd)
4
+ # Homepage:: http://rubyeventmachine.com
5
+ # Date:: 8 April 2006
6
+ #
7
+ # See EventMachine and EventMachine::Connection for documentation and
8
+ # usage examples.
9
+ #
10
+ #----------------------------------------------------------------------------
11
+ #
12
+ # Copyright (C) 2006-07 by Francis Cianfrocca. All Rights Reserved.
13
+ # Gmail: blackhedd
14
+ #
15
+ # This program is free software; you can redistribute it and/or modify
16
+ # it under the terms of either: 1) the GNU General Public License
17
+ # as published by the Free Software Foundation; either version 2 of the
18
+ # License, or (at your option) any later version; or 2) Ruby's License.
19
+ #
20
+ # See the file COPYING for complete licensing information.
21
+ #
22
+ #---------------------------------------------------------------------------
23
+ #
24
+ #
25
+ #
26
+ #
27
+
28
+ $:.unshift "../lib"
29
+ require 'eventmachine'
30
+ require 'test/unit'
31
+
32
+ class TestNextTick < Test::Unit::TestCase
33
+
34
+ def test_tick_arg
35
+ pr = proc {EM.stop}
36
+ EM.run {
37
+ EM.next_tick pr
38
+ }
39
+ assert true
40
+ end
41
+
42
+ def test_tick_block
43
+ EM.run {
44
+ EM.next_tick {EM.stop}
45
+ }
46
+ assert true
47
+ end
48
+
49
+ # This illustrates the solution to a long-standing problem.
50
+ # It's now possible to correctly nest calls to EM#run.
51
+ # See the source code commentary for EM#run for more info.
52
+ #
53
+ def test_run_run
54
+ EM.run {
55
+ EM.run {
56
+ EM.next_tick {EM.stop}
57
+ }
58
+ }
59
+ end
60
+
61
+ def test_pre_run_queue
62
+ x = false
63
+ EM.next_tick { EM.stop; x = true }
64
+ EM.run { EM.add_timer(0.2) { EM.stop } }
65
+ assert x
66
+ end
67
+
68
+ def test_cleanup_after_stop
69
+ x = true
70
+ EM.run{
71
+ EM.next_tick{
72
+ EM.stop
73
+ EM.next_tick{ x=false }
74
+ }
75
+ }
76
+ EM.run{
77
+ EM.next_tick{ EM.stop }
78
+ }
79
+ assert x
80
+ end
81
+
82
+ # We now support an additional parameter for EM#run.
83
+ # You can pass two procs to EM#run now. The first is executed as the normal
84
+ # run block. The second (if given) is scheduled for execution after the
85
+ # reactor loop completes.
86
+ # The reason for supporting this is subtle. There has always been an expectation
87
+ # that EM#run doesn't return until after the reactor loop ends. But now it's
88
+ # possible to nest calls to EM#run, which means that a nested call WILL
89
+ # RETURN. In order to write code that will run correctly either way, it's
90
+ # recommended to put any code which must execute after the reactor completes
91
+ # in the second parameter.
92
+ #
93
+ def test_run_run_2
94
+ a = proc {EM.stop}
95
+ b = proc {assert true}
96
+ EM.run a, b
97
+ end
98
+
99
+
100
+ # This illustrates that EM#run returns when it's called nested.
101
+ # This isn't a feature, rather it's something to be wary of when writing code
102
+ # that must run correctly even if EM#run is called while a reactor is already
103
+ # running.
104
+ def test_run_run_3
105
+ a = []
106
+ EM.run {
107
+ EM.run proc {EM.stop}, proc {a << 2}
108
+ a << 1
109
+ }
110
+ assert_equal( [1,2], a )
111
+ end
112
+
113
+
114
+ def test_schedule_on_reactor_thread
115
+ x = false
116
+ EM.run do
117
+ EM.schedule { x = true }
118
+ EM.stop
119
+ end
120
+ assert x
121
+ end
122
+
123
+ def test_schedule_from_thread
124
+ x = false
125
+ EM.run do
126
+ Thread.new { EM.schedule { x = true } }.join
127
+ assert !x
128
+ EM.next_tick { EM.stop }
129
+ end
130
+ assert x
131
+ end
132
+
133
+ end
@@ -0,0 +1,37 @@
1
+ $:.unshift "../lib"
2
+ require 'eventmachine'
3
+ require 'test/unit'
4
+
5
+ class TestObjectProtocol < Test::Unit::TestCase
6
+ Host = "127.0.0.1"
7
+ Port = 9550
8
+
9
+ module Server
10
+ include EM::P::ObjectProtocol
11
+ def post_init
12
+ send_object :hello=>'world'
13
+ end
14
+ def receive_object obj
15
+ $server = obj
16
+ EM.stop
17
+ end
18
+ end
19
+
20
+ module Client
21
+ include EM::P::ObjectProtocol
22
+ def receive_object obj
23
+ $client = obj
24
+ send_object 'you_said'=>obj
25
+ end
26
+ end
27
+
28
+ def test_send_receive
29
+ EM.run{
30
+ EM.start_server Host, Port, Server
31
+ EM.connect Host, Port, Client
32
+ }
33
+
34
+ assert($client == {:hello=>'world'})
35
+ assert($server == {'you_said'=>{:hello=>'world'}})
36
+ end
37
+ end
@@ -0,0 +1,48 @@
1
+ $:.unshift "../lib"
2
+ require 'eventmachine'
3
+ require 'test/unit'
4
+
5
+ class TestProcessWatch < Test::Unit::TestCase
6
+ module ParentProcessWatcher
7
+ def process_forked
8
+ $forked = true
9
+ end
10
+ end
11
+
12
+ module ChildProcessWatcher
13
+ def process_exited
14
+ $exited = true
15
+ end
16
+ def unbind
17
+ $unbind = true
18
+ EM.stop
19
+ end
20
+ end
21
+
22
+ def setup
23
+ EM.kqueue = true if EM.kqueue?
24
+ end
25
+
26
+ def teardown
27
+ EM.kqueue = false if EM.kqueue?
28
+ end
29
+
30
+ def test_events
31
+ EM.run{
32
+ # watch ourselves for a fork notification
33
+ EM.watch_process(Process.pid, ParentProcessWatcher)
34
+ $fork_pid = fork{ sleep }
35
+ child = EM.watch_process($fork_pid, ChildProcessWatcher)
36
+ $pid = child.pid
37
+
38
+ EM.add_timer(0.5){
39
+ Process.kill('TERM', $fork_pid)
40
+ }
41
+ }
42
+
43
+ assert_equal($pid, $fork_pid)
44
+ assert($forked)
45
+ assert($exited)
46
+ assert($unbind)
47
+ end
48
+ end
@@ -0,0 +1,128 @@
1
+ # $Id$
2
+ #
3
+ # Author:: Francis Cianfrocca (gmail: blackhedd)
4
+ # Homepage:: http://rubyeventmachine.com
5
+ # Date:: 8 April 2006
6
+ #
7
+ # See EventMachine and EventMachine::Connection for documentation and
8
+ # usage examples.
9
+ #
10
+ #----------------------------------------------------------------------------
11
+ #
12
+ # Copyright (C) 2006-07 by Francis Cianfrocca. All Rights Reserved.
13
+ # Gmail: blackhedd
14
+ #
15
+ # This program is free software; you can redistribute it and/or modify
16
+ # it under the terms of either: 1) the GNU General Public License
17
+ # as published by the Free Software Foundation; either version 2 of the
18
+ # License, or (at your option) any later version; or 2) Ruby's License.
19
+ #
20
+ # See the file COPYING for complete licensing information.
21
+ #
22
+ #---------------------------------------------------------------------------
23
+ #
24
+ #
25
+ #
26
+
27
+ $:.unshift "../lib"
28
+ require 'eventmachine'
29
+ require 'test/unit'
30
+
31
+ class TestProcesses < Test::Unit::TestCase
32
+
33
+ # EM::DeferrableChildProcess is a sugaring of a common use-case
34
+ # involving EM::popen.
35
+ # Call the #open method on EM::DeferrableChildProcess, passing
36
+ # a command-string. #open immediately returns an EM::Deferrable
37
+ # object. It also schedules the forking of a child process, which
38
+ # will execute the command passed to #open.
39
+ # When the forked child terminates, the Deferrable will be signalled
40
+ # and execute its callbacks, passing the data that the child process
41
+ # wrote to stdout.
42
+ #
43
+ def test_deferrable_child_process
44
+ ls = ""
45
+ EM.run {
46
+ d = EM::DeferrableChildProcess.open( "ls -ltr" )
47
+ d.callback {|data_from_child|
48
+ ls = data_from_child
49
+ EM.stop
50
+ }
51
+ }
52
+ assert( ls.length > 0)
53
+ end
54
+
55
+ def setup
56
+ $out = nil
57
+ $status = nil
58
+ end
59
+
60
+ def test_em_system
61
+ EM.run{
62
+ EM.system('ls'){ |out,status| $out, $status = out, status; EM.stop }
63
+ }
64
+
65
+ assert( $out.length > 0 )
66
+ assert_equal($status.exitstatus, 0)
67
+ assert_equal($status.class, Process::Status)
68
+ end
69
+
70
+ def test_em_system_pid
71
+ $pids = []
72
+
73
+ EM.run{
74
+ $pids << EM.system('echo hi', proc{ |out,status|$pids << status.pid; EM.stop })
75
+ }
76
+
77
+ assert_equal $pids[0], $pids[1]
78
+ end
79
+
80
+ def test_em_system_with_proc
81
+ EM.run{
82
+ EM.system('ls', proc{ |out,status| $out, $status = out, status; EM.stop })
83
+ }
84
+
85
+ assert( $out.length > 0 )
86
+ assert_equal($status.exitstatus, 0)
87
+ assert_equal($status.class, Process::Status)
88
+ end
89
+
90
+ def test_em_system_with_two_procs
91
+ EM.run{
92
+ EM.system('sh', proc{ |process|
93
+ process.send_data("echo hello\n")
94
+ process.send_data("exit\n")
95
+ }, proc{ |out,status|
96
+ $out = out
97
+ $status = status
98
+ EM.stop
99
+ })
100
+ }
101
+
102
+ assert_equal("hello\n", $out)
103
+ end
104
+
105
+ def test_em_system_cmd_arguments
106
+ EM.run{
107
+ EM.system('sh', '--version', proc{ |process|
108
+ }, proc{ |out,status|
109
+ $out = out
110
+ $status = status
111
+ EM.stop
112
+ })
113
+ }
114
+
115
+ assert_match(/version/i, $out)
116
+ end
117
+
118
+ def test_em_system_spaced_arguments
119
+ EM.run{
120
+ EM.system('ruby', '-e', 'puts "hello"', proc{ |out,status|
121
+ $out = out
122
+ EM.stop
123
+ })
124
+ }
125
+
126
+ assert_equal("hello\n", $out)
127
+ end
128
+ end
@@ -0,0 +1,92 @@
1
+ $:.unshift "../lib"
2
+ require 'eventmachine'
3
+ require 'test/unit'
4
+
5
+ class TestProxyConnection < Test::Unit::TestCase
6
+
7
+ module ProxyConnection
8
+ def initialize(client, request)
9
+ @client, @request = client, request
10
+ end
11
+
12
+ def post_init
13
+ EM::enable_proxy(self, @client)
14
+ end
15
+
16
+ def connection_completed
17
+ EM.next_tick {
18
+ send_data @request
19
+ }
20
+ end
21
+
22
+ def proxy_target_unbound
23
+ $unbound_early = true
24
+ EM.stop
25
+ end
26
+
27
+ def unbind
28
+ @client.close_connection_after_writing
29
+ end
30
+ end
31
+
32
+ module Client
33
+ def connection_completed
34
+ send_data "EventMachine rocks!"
35
+ end
36
+
37
+ def receive_data(data)
38
+ $client_data = data
39
+ end
40
+
41
+ def unbind
42
+ EM.stop
43
+ end
44
+ end
45
+
46
+ module Client2
47
+ include Client
48
+ def unbind; end
49
+ end
50
+
51
+ module Server
52
+ def receive_data(data)
53
+ send_data "I know!" if data == "EventMachine rocks!"
54
+ close_connection_after_writing
55
+ end
56
+ end
57
+
58
+ module ProxyServer
59
+ def receive_data(data)
60
+ EM.connect("127.0.0.1", 54321, ProxyConnection, self, data)
61
+ end
62
+ end
63
+
64
+ module EarlyClosingProxy
65
+ def receive_data(data)
66
+ EM.connect("127.0.0.1", 54321, ProxyConnection, self, data)
67
+ close_connection
68
+ end
69
+ end
70
+
71
+ def test_proxy_connection
72
+ EM.run {
73
+ EM.start_server("127.0.0.1", 54321, Server)
74
+ EM.start_server("127.0.0.1", 12345, ProxyServer)
75
+ EM.connect("127.0.0.1", 12345, Client)
76
+ }
77
+
78
+ assert_equal("I know!", $client_data)
79
+ end
80
+
81
+ def test_early_close
82
+ $client_data = nil
83
+ EM.run {
84
+ EM.start_server("127.0.0.1", 54321, Server)
85
+ EM.start_server("127.0.0.1", 12345, EarlyClosingProxy)
86
+ EM.connect("127.0.0.1", 12345, Client2)
87
+ }
88
+
89
+ assert($unbound_early)
90
+ end
91
+
92
+ end
@@ -0,0 +1,125 @@
1
+ # $Id$
2
+ #
3
+ # Author:: Francis Cianfrocca (gmail: blackhedd)
4
+ # Homepage:: http://rubyeventmachine.com
5
+ # Date:: 8 April 2006
6
+ #
7
+ # See EventMachine and EventMachine::Connection for documentation and
8
+ # usage examples.
9
+ #
10
+ #----------------------------------------------------------------------------
11
+ #
12
+ # Copyright (C) 2006-07 by Francis Cianfrocca. All Rights Reserved.
13
+ # Gmail: blackhedd
14
+ #
15
+ # This program is free software; you can redistribute it and/or modify
16
+ # it under the terms of either: 1) the GNU General Public License
17
+ # as published by the Free Software Foundation; either version 2 of the
18
+ # License, or (at your option) any later version; or 2) Ruby's License.
19
+ #
20
+ # See the file COPYING for complete licensing information.
21
+ #
22
+ #---------------------------------------------------------------------------
23
+ #
24
+ #
25
+ #
26
+
27
+ $:.unshift "../lib"
28
+ require 'eventmachine'
29
+ require 'test/unit'
30
+
31
+ class TestPure < Test::Unit::TestCase
32
+
33
+
34
+ Host,Port = "0.0.0.0", 9060
35
+
36
+
37
+ # These tests are intended to exercise problems that come up in the
38
+ # pure-Ruby implementation. However, we DON'T constrain them such that
39
+ # they only run in pure-Ruby. These tests need to work identically in
40
+ # any implementation.
41
+
42
+ def setup
43
+ end
44
+
45
+ def teardown
46
+ end
47
+
48
+ #-------------------------------------
49
+
50
+ # The EM reactor needs to run down open connections and release other resources
51
+ # when it stops running. Make sure this happens even if user code throws a Ruby
52
+ # exception.
53
+ # One way to see this is to run identical tests that open a TCP server and throw
54
+ # an exception. (We do this twice because an exception aborts a test. We make the
55
+ # two tests identical except for the method name because we can't predict the order
56
+ # in which the test harness will run them.)
57
+ # If exception handling is incorrect, the second test will fail with a no-bind error
58
+ # because the TCP server opened in the first test will not have been closed.
59
+ #
60
+ def run_exception
61
+ EM.run {
62
+ EM.start_server Host, Port
63
+ raise "an exception"
64
+ }
65
+ end
66
+ def test_exception_1
67
+ assert_raises( RuntimeError ) { run_exception }
68
+ end
69
+ def test_exception_2
70
+ ex_class = RUBY_PLATFORM == 'java' ? NativeException : RuntimeError
71
+ assert_raises( ex_class ) { run_exception }
72
+ end
73
+
74
+
75
+ # Under some circumstances, the pure Ruby library would emit an Errno::ECONNREFUSED
76
+ # exception on certain kinds of TCP connect-errors.
77
+ # It's always been something of an open question whether EM should throw an exception
78
+ # in these cases but the defined answer has always been to catch it the unbind method.
79
+ # With a connect failure, the latter will always fire, but connection_completed will
80
+ # never fire. So even though the point is arguable, it's incorrect for the pure Ruby
81
+ # version to throw an exception.
82
+ module TestConnrefused
83
+ def unbind
84
+ EM.stop
85
+ end
86
+ def connection_completed
87
+ raise "should never get here"
88
+ end
89
+ end
90
+ def test_connrefused
91
+ EM.run {
92
+ EM.connect "0.0.0.0", 60001, TestConnrefused
93
+ }
94
+ end
95
+
96
+
97
+ # Make sure connection_completed gets called as expected with TCP clients. This is the
98
+ # opposite of test_connrefused.
99
+ # If the test fails, it will hang because EM.stop never gets called.
100
+ #
101
+ module TestConnaccepted
102
+ def connection_completed
103
+ EM.stop
104
+ end
105
+ end
106
+ def test_connaccepted
107
+ timeout = false
108
+ EM.run {
109
+ EM.start_server "0.0.0.0", 60002
110
+ EM.connect "0.0.0.0", 60002, TestConnaccepted
111
+ EM::Timer.new(1) {timeout = true; EM.stop}
112
+ }
113
+ assert_equal( false, timeout )
114
+ end
115
+
116
+ def test_reactor_running
117
+ a = false
118
+ EM.run {
119
+ a = EM.reactor_running?
120
+ EM.next_tick {EM.stop}
121
+ }
122
+ assert a
123
+ end
124
+
125
+ end