eventmachine 1.0.0.beta.2-x86-mingw32
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.
- data/.gitignore +16 -0
- data/Gemfile +1 -0
- data/README +81 -0
- data/Rakefile +11 -0
- data/docs/COPYING +60 -0
- data/docs/ChangeLog +211 -0
- data/docs/DEFERRABLES +246 -0
- data/docs/EPOLL +141 -0
- data/docs/GNU +281 -0
- data/docs/INSTALL +13 -0
- data/docs/KEYBOARD +42 -0
- data/docs/LEGAL +25 -0
- data/docs/LIGHTWEIGHT_CONCURRENCY +130 -0
- data/docs/PURE_RUBY +75 -0
- data/docs/RELEASE_NOTES +94 -0
- data/docs/SMTP +4 -0
- data/docs/SPAWNED_PROCESSES +148 -0
- data/docs/TODO +8 -0
- data/eventmachine.gemspec +33 -0
- data/examples/ex_channel.rb +43 -0
- data/examples/ex_queue.rb +2 -0
- data/examples/ex_tick_loop_array.rb +15 -0
- data/examples/ex_tick_loop_counter.rb +32 -0
- data/examples/helper.rb +2 -0
- data/ext/binder.cpp +124 -0
- data/ext/binder.h +46 -0
- data/ext/cmain.cpp +838 -0
- data/ext/ed.cpp +1884 -0
- data/ext/ed.h +418 -0
- data/ext/em.cpp +2348 -0
- data/ext/em.h +228 -0
- data/ext/eventmachine.h +123 -0
- data/ext/extconf.rb +157 -0
- data/ext/fastfilereader/extconf.rb +85 -0
- data/ext/fastfilereader/mapper.cpp +214 -0
- data/ext/fastfilereader/mapper.h +59 -0
- data/ext/fastfilereader/rubymain.cpp +127 -0
- data/ext/kb.cpp +79 -0
- data/ext/page.cpp +107 -0
- data/ext/page.h +51 -0
- data/ext/pipe.cpp +347 -0
- data/ext/project.h +155 -0
- data/ext/rubymain.cpp +1200 -0
- data/ext/ssl.cpp +460 -0
- data/ext/ssl.h +94 -0
- data/java/.classpath +8 -0
- data/java/.project +17 -0
- data/java/src/com/rubyeventmachine/EmReactor.java +571 -0
- data/java/src/com/rubyeventmachine/EmReactorException.java +40 -0
- data/java/src/com/rubyeventmachine/EventableChannel.java +69 -0
- data/java/src/com/rubyeventmachine/EventableDatagramChannel.java +189 -0
- data/java/src/com/rubyeventmachine/EventableSocketChannel.java +364 -0
- data/lib/em/buftok.rb +138 -0
- data/lib/em/callback.rb +26 -0
- data/lib/em/channel.rb +57 -0
- data/lib/em/connection.rb +569 -0
- data/lib/em/deferrable.rb +206 -0
- data/lib/em/file_watch.rb +54 -0
- data/lib/em/future.rb +61 -0
- data/lib/em/iterator.rb +270 -0
- data/lib/em/messages.rb +66 -0
- data/lib/em/process_watch.rb +44 -0
- data/lib/em/processes.rb +119 -0
- data/lib/em/protocols.rb +36 -0
- data/lib/em/protocols/header_and_content.rb +138 -0
- data/lib/em/protocols/httpclient.rb +268 -0
- data/lib/em/protocols/httpclient2.rb +590 -0
- data/lib/em/protocols/line_and_text.rb +125 -0
- data/lib/em/protocols/line_protocol.rb +28 -0
- data/lib/em/protocols/linetext2.rb +161 -0
- data/lib/em/protocols/memcache.rb +323 -0
- data/lib/em/protocols/object_protocol.rb +45 -0
- data/lib/em/protocols/postgres3.rb +247 -0
- data/lib/em/protocols/saslauth.rb +175 -0
- data/lib/em/protocols/smtpclient.rb +357 -0
- data/lib/em/protocols/smtpserver.rb +640 -0
- data/lib/em/protocols/socks4.rb +66 -0
- data/lib/em/protocols/stomp.rb +200 -0
- data/lib/em/protocols/tcptest.rb +53 -0
- data/lib/em/pure_ruby.rb +1013 -0
- data/lib/em/queue.rb +62 -0
- data/lib/em/spawnable.rb +85 -0
- data/lib/em/streamer.rb +130 -0
- data/lib/em/tick_loop.rb +85 -0
- data/lib/em/timers.rb +57 -0
- data/lib/em/version.rb +3 -0
- data/lib/eventmachine.rb +1548 -0
- data/lib/jeventmachine.rb +258 -0
- data/lib/rubyeventmachine.rb +2 -0
- data/setup.rb +1585 -0
- data/tasks/cpp.rake_example +77 -0
- data/tasks/doc.rake +30 -0
- data/tasks/package.rake +85 -0
- data/tasks/test.rake +6 -0
- data/tests/client.crt +31 -0
- data/tests/client.key +51 -0
- data/tests/test_attach.rb +136 -0
- data/tests/test_basic.rb +249 -0
- data/tests/test_channel.rb +64 -0
- data/tests/test_connection_count.rb +35 -0
- data/tests/test_defer.rb +49 -0
- data/tests/test_deferrable.rb +35 -0
- data/tests/test_epoll.rb +160 -0
- data/tests/test_error_handler.rb +35 -0
- data/tests/test_errors.rb +82 -0
- data/tests/test_exc.rb +55 -0
- data/tests/test_file_watch.rb +49 -0
- data/tests/test_futures.rb +198 -0
- data/tests/test_get_sock_opt.rb +30 -0
- data/tests/test_handler_check.rb +37 -0
- data/tests/test_hc.rb +190 -0
- data/tests/test_httpclient.rb +227 -0
- data/tests/test_httpclient2.rb +154 -0
- data/tests/test_inactivity_timeout.rb +50 -0
- data/tests/test_kb.rb +60 -0
- data/tests/test_ltp.rb +190 -0
- data/tests/test_ltp2.rb +317 -0
- data/tests/test_next_tick.rb +133 -0
- data/tests/test_object_protocol.rb +37 -0
- data/tests/test_pause.rb +70 -0
- data/tests/test_pending_connect_timeout.rb +48 -0
- data/tests/test_process_watch.rb +50 -0
- data/tests/test_processes.rb +128 -0
- data/tests/test_proxy_connection.rb +144 -0
- data/tests/test_pure.rb +134 -0
- data/tests/test_queue.rb +44 -0
- data/tests/test_running.rb +42 -0
- data/tests/test_sasl.rb +72 -0
- data/tests/test_send_file.rb +251 -0
- data/tests/test_servers.rb +76 -0
- data/tests/test_smtpclient.rb +83 -0
- data/tests/test_smtpserver.rb +85 -0
- data/tests/test_spawn.rb +322 -0
- data/tests/test_ssl_args.rb +79 -0
- data/tests/test_ssl_methods.rb +50 -0
- data/tests/test_ssl_verify.rb +82 -0
- data/tests/test_tick_loop.rb +59 -0
- data/tests/test_timers.rb +160 -0
- data/tests/test_ud.rb +36 -0
- data/tests/testem.rb +31 -0
- metadata +240 -0
@@ -0,0 +1,64 @@
|
|
1
|
+
$:.unshift "../lib"
|
2
|
+
require 'eventmachine'
|
3
|
+
require 'test/unit'
|
4
|
+
|
5
|
+
class TestEventMachineChannel < Test::Unit::TestCase
|
6
|
+
def test_channel_subscribe
|
7
|
+
s = 0
|
8
|
+
EM.run do
|
9
|
+
c = EM::Channel.new
|
10
|
+
c.subscribe { |v| s = v; EM.stop }
|
11
|
+
c << 1
|
12
|
+
end
|
13
|
+
assert_equal 1, s
|
14
|
+
end
|
15
|
+
|
16
|
+
def test_channel_unsubscribe
|
17
|
+
s = 0
|
18
|
+
EM.run do
|
19
|
+
c = EM::Channel.new
|
20
|
+
subscription = c.subscribe { |v| s = v }
|
21
|
+
c.unsubscribe(subscription)
|
22
|
+
c << 1
|
23
|
+
EM.next_tick { EM.stop }
|
24
|
+
end
|
25
|
+
assert_not_equal 1, s
|
26
|
+
end
|
27
|
+
|
28
|
+
def test_channel_pop
|
29
|
+
s = 0
|
30
|
+
EM.run do
|
31
|
+
c = EM::Channel.new
|
32
|
+
c.pop{ |v| s = v }
|
33
|
+
c.push(1,2,3)
|
34
|
+
c << 4
|
35
|
+
c << 5
|
36
|
+
EM.next_tick { EM.stop }
|
37
|
+
end
|
38
|
+
assert_equal 1, s
|
39
|
+
end
|
40
|
+
|
41
|
+
def test_channel_reactor_thread_push
|
42
|
+
out = []
|
43
|
+
c = EM::Channel.new
|
44
|
+
c.subscribe { |v| out << v }
|
45
|
+
Thread.new { c.push(1,2,3) }.join
|
46
|
+
assert out.empty?
|
47
|
+
|
48
|
+
EM.run { EM.next_tick { EM.stop } }
|
49
|
+
|
50
|
+
assert_equal [1,2,3], out
|
51
|
+
end
|
52
|
+
|
53
|
+
def test_channel_reactor_thread_callback
|
54
|
+
out = []
|
55
|
+
c = EM::Channel.new
|
56
|
+
Thread.new { c.subscribe { |v| out << v } }.join
|
57
|
+
c.push(1,2,3)
|
58
|
+
assert out.empty?
|
59
|
+
|
60
|
+
EM.run { EM.next_tick { EM.stop } }
|
61
|
+
|
62
|
+
assert_equal [1,2,3], out
|
63
|
+
end
|
64
|
+
end
|
@@ -0,0 +1,35 @@
|
|
1
|
+
$:.unshift "../lib"
|
2
|
+
require 'eventmachine'
|
3
|
+
require 'test/unit'
|
4
|
+
|
5
|
+
class TestConnectionCount < Test::Unit::TestCase
|
6
|
+
def test_idle_connection_count
|
7
|
+
EM.run {
|
8
|
+
$count = EM.connection_count
|
9
|
+
EM.stop_event_loop
|
10
|
+
}
|
11
|
+
|
12
|
+
assert_equal(0, $count)
|
13
|
+
end
|
14
|
+
|
15
|
+
module Client
|
16
|
+
def connection_completed
|
17
|
+
$client_conns += 1
|
18
|
+
EM.stop if $client_conns == 3
|
19
|
+
end
|
20
|
+
end
|
21
|
+
|
22
|
+
def test_with_some_connections
|
23
|
+
EM.run {
|
24
|
+
$client_conns = 0
|
25
|
+
$initial_conns = EM.connection_count
|
26
|
+
EM.start_server("127.0.0.1", 9999)
|
27
|
+
$server_conns = EM.connection_count
|
28
|
+
3.times { EM.connect("127.0.0.1", 9999, Client) }
|
29
|
+
}
|
30
|
+
|
31
|
+
assert_equal(0, $initial_conns)
|
32
|
+
assert_equal(1, $server_conns)
|
33
|
+
assert_equal(4, $client_conns + $server_conns)
|
34
|
+
end
|
35
|
+
end
|
data/tests/test_defer.rb
ADDED
@@ -0,0 +1,49 @@
|
|
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
|
+
unless RUBY_VERSION >= '1.9.0'
|
32
|
+
class TestDeferUsage < Test::Unit::TestCase
|
33
|
+
|
34
|
+
def test_defers
|
35
|
+
n = 0
|
36
|
+
n_times = 20
|
37
|
+
EM.run {
|
38
|
+
n_times.times {
|
39
|
+
work_proc = proc { n += 1 }
|
40
|
+
callback = proc { EM.stop if n == n_times }
|
41
|
+
EM.defer work_proc, callback
|
42
|
+
}
|
43
|
+
}
|
44
|
+
assert_equal( n, n_times )
|
45
|
+
end
|
46
|
+
|
47
|
+
end
|
48
|
+
end
|
49
|
+
|
@@ -0,0 +1,35 @@
|
|
1
|
+
$:.unshift "../lib"
|
2
|
+
require 'eventmachine'
|
3
|
+
require 'test/unit'
|
4
|
+
|
5
|
+
class TestDeferrable < Test::Unit::TestCase
|
6
|
+
class Later
|
7
|
+
include EM::Deferrable
|
8
|
+
end
|
9
|
+
|
10
|
+
def test_timeout_without_args
|
11
|
+
$args = "unset"
|
12
|
+
|
13
|
+
EM.run {
|
14
|
+
df = Later.new
|
15
|
+
df.timeout(0.2)
|
16
|
+
df.errback { $args = "none" }
|
17
|
+
EM.add_timer(0.5) { EM.stop }
|
18
|
+
}
|
19
|
+
|
20
|
+
assert_equal("none", $args)
|
21
|
+
end
|
22
|
+
|
23
|
+
def test_timeout_with_args
|
24
|
+
$args = "unset"
|
25
|
+
|
26
|
+
EM.run {
|
27
|
+
df = Later.new
|
28
|
+
df.timeout(0.2, :timeout, :foo)
|
29
|
+
df.errback { |type, name| $args = [type, name] }
|
30
|
+
EM.add_timer(0.5) { EM.stop }
|
31
|
+
}
|
32
|
+
|
33
|
+
assert_equal([:timeout, :foo], $args)
|
34
|
+
end
|
35
|
+
end
|
data/tests/test_epoll.rb
ADDED
@@ -0,0 +1,160 @@
|
|
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
|
+
# TODO, and I know this doesn't belong here, but if a datagram calls
|
27
|
+
# send_data outside of a receive_data, there is no return address, and
|
28
|
+
# the result is a very confusing error message.
|
29
|
+
#
|
30
|
+
|
31
|
+
require 'eventmachine'
|
32
|
+
require 'test/unit'
|
33
|
+
|
34
|
+
|
35
|
+
class TestEpoll < Test::Unit::TestCase
|
36
|
+
|
37
|
+
module TestEchoServer
|
38
|
+
def receive_data data
|
39
|
+
send_data data
|
40
|
+
close_connection_after_writing
|
41
|
+
end
|
42
|
+
end
|
43
|
+
|
44
|
+
module TestEchoClient
|
45
|
+
def connection_completed
|
46
|
+
send_data "ABCDE"
|
47
|
+
$max += 1
|
48
|
+
end
|
49
|
+
def receive_data data
|
50
|
+
raise "bad response" unless data == "ABCDE"
|
51
|
+
end
|
52
|
+
def unbind
|
53
|
+
$n -= 1
|
54
|
+
EM.stop if $n == 0
|
55
|
+
end
|
56
|
+
end
|
57
|
+
|
58
|
+
|
59
|
+
# We can set the rlimit/nofile of a process but we can only set it
|
60
|
+
# higher if we're running as root.
|
61
|
+
# On most systems, the default value is 1024.
|
62
|
+
# Java doesn't (currently) implement this.
|
63
|
+
def test_rlimit
|
64
|
+
unless RUBY_PLATFORM =~ /java/ or EM.set_descriptor_table_size >= 1024
|
65
|
+
a = EM.set_descriptor_table_size
|
66
|
+
assert( a <= 1024 )
|
67
|
+
a = EM.set_descriptor_table_size( 1024 )
|
68
|
+
assert( a == 1024 )
|
69
|
+
end
|
70
|
+
end
|
71
|
+
|
72
|
+
# Run a high-volume version of this test by kicking the number of connections
|
73
|
+
# up past 512. (Each connection uses two sockets, a client and a server.)
|
74
|
+
# (Will require running the test as root)
|
75
|
+
# This test exercises TCP clients and servers.
|
76
|
+
#
|
77
|
+
# XXX this test causes all sort of weird issues on OSX (when run as part of the suite)
|
78
|
+
def _test_descriptors
|
79
|
+
EM.epoll
|
80
|
+
s = EM.set_descriptor_table_size 60000
|
81
|
+
EM.run {
|
82
|
+
EM.start_server "127.0.0.1", 9800, TestEchoServer
|
83
|
+
$n = 0
|
84
|
+
$max = 0
|
85
|
+
100.times {
|
86
|
+
EM.connect("127.0.0.1", 9800, TestEchoClient) {$n += 1}
|
87
|
+
}
|
88
|
+
}
|
89
|
+
assert_equal(0, $n)
|
90
|
+
assert_equal(100, $max)
|
91
|
+
end
|
92
|
+
|
93
|
+
def test_defer
|
94
|
+
n = 0
|
95
|
+
work_proc = proc {n += 1}
|
96
|
+
callback_proc = proc {EM.stop}
|
97
|
+
EM.run {
|
98
|
+
EM.defer work_proc, callback_proc
|
99
|
+
}
|
100
|
+
assert_equal( 1, n )
|
101
|
+
end unless RUBY_VERSION >= '1.9.0'
|
102
|
+
|
103
|
+
|
104
|
+
module TestDatagramServer
|
105
|
+
def receive_data dgm
|
106
|
+
$in = dgm
|
107
|
+
send_data "abcdefghij"
|
108
|
+
end
|
109
|
+
end
|
110
|
+
module TestDatagramClient
|
111
|
+
def post_init
|
112
|
+
send_datagram "1234567890", "127.0.0.1", 9500
|
113
|
+
end
|
114
|
+
def receive_data dgm
|
115
|
+
$out = dgm
|
116
|
+
EM.stop
|
117
|
+
end
|
118
|
+
end
|
119
|
+
|
120
|
+
def test_datagrams
|
121
|
+
$in = $out = ""
|
122
|
+
EM.run {
|
123
|
+
EM.open_datagram_socket "127.0.0.1", 9500, TestDatagramServer
|
124
|
+
EM.open_datagram_socket "127.0.0.1", 0, TestDatagramClient
|
125
|
+
}
|
126
|
+
assert_equal( "1234567890", $in )
|
127
|
+
assert_equal( "abcdefghij", $out )
|
128
|
+
end
|
129
|
+
|
130
|
+
# XXX this test fails randomly..
|
131
|
+
def _test_unix_domain
|
132
|
+
fn = "/tmp/xxx.chain"
|
133
|
+
EM.epoll
|
134
|
+
s = EM.set_descriptor_table_size 60000
|
135
|
+
EM.run {
|
136
|
+
# The pure-Ruby version won't let us open the socket if the node already exists.
|
137
|
+
# Not sure, that actually may be correct and the compiled version is wrong.
|
138
|
+
# Pure Ruby also oddly won't let us make that many connections. This test used
|
139
|
+
# to run 100 times. Not sure where that lower connection-limit is coming from in
|
140
|
+
# pure Ruby.
|
141
|
+
# Let's not sweat the Unix-ness of the filename, since this test can't possibly
|
142
|
+
# work on Windows anyway.
|
143
|
+
#
|
144
|
+
File.unlink(fn) if File.exist?(fn)
|
145
|
+
EM.start_unix_domain_server fn, TestEchoServer
|
146
|
+
$n = 0
|
147
|
+
$max = 0
|
148
|
+
50.times {
|
149
|
+
EM.connect_unix_domain(fn, TestEchoClient) {$n += 1}
|
150
|
+
}
|
151
|
+
EM::add_timer(1) { $stderr.puts("test_unix_domain timed out!"); EM::stop }
|
152
|
+
}
|
153
|
+
assert_equal(0, $n)
|
154
|
+
assert_equal(50, $max)
|
155
|
+
ensure
|
156
|
+
File.unlink(fn) if File.exist?(fn)
|
157
|
+
end
|
158
|
+
|
159
|
+
end
|
160
|
+
|
@@ -0,0 +1,35 @@
|
|
1
|
+
$:.unshift "../lib"
|
2
|
+
require 'eventmachine'
|
3
|
+
require 'test/unit'
|
4
|
+
|
5
|
+
class TestErrorHandler < Test::Unit::TestCase
|
6
|
+
def test_error_handler
|
7
|
+
error = nil
|
8
|
+
EM.error_handler{ |e|
|
9
|
+
error = e
|
10
|
+
EM.error_handler(nil)
|
11
|
+
EM.stop
|
12
|
+
}
|
13
|
+
|
14
|
+
assert_nothing_raised do
|
15
|
+
EM.run{
|
16
|
+
EM.add_timer(0){
|
17
|
+
raise 'test'
|
18
|
+
}
|
19
|
+
}
|
20
|
+
end
|
21
|
+
|
22
|
+
assert_equal error.class, RuntimeError
|
23
|
+
assert_equal error.message, 'test'
|
24
|
+
end
|
25
|
+
|
26
|
+
def test_without_error_handler
|
27
|
+
assert_raise RuntimeError do
|
28
|
+
EM.run{
|
29
|
+
EM.add_timer(0){
|
30
|
+
raise 'test'
|
31
|
+
}
|
32
|
+
}
|
33
|
+
end
|
34
|
+
end
|
35
|
+
end
|
@@ -0,0 +1,82 @@
|
|
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
|
+
###### THIS TEST IS NOW OBSOLETE.
|
29
|
+
###### As of 27Dec07, the hookable error handling is obsolete because
|
30
|
+
###### of its performance impact.
|
31
|
+
|
32
|
+
|
33
|
+
$:.unshift "../lib"
|
34
|
+
require 'eventmachine'
|
35
|
+
require 'test/unit'
|
36
|
+
|
37
|
+
class TestErrors < Test::Unit::TestCase
|
38
|
+
|
39
|
+
Localhost = "127.0.0.1"
|
40
|
+
Localport = 9801
|
41
|
+
|
42
|
+
def setup
|
43
|
+
end
|
44
|
+
|
45
|
+
def obsolete_teardown
|
46
|
+
# Calling #set_runtime_error_hook with no block restores the
|
47
|
+
# default handling of runtime_errors.
|
48
|
+
#
|
49
|
+
EM.set_runtime_error_hook
|
50
|
+
end
|
51
|
+
|
52
|
+
def test_no_tests_stub
|
53
|
+
end
|
54
|
+
|
55
|
+
# EM has a default handler for RuntimeErrors that are emitted from
|
56
|
+
# user written code. You can override the handler if you wish, but it's
|
57
|
+
# easier to call #set_runtime_error_hook.
|
58
|
+
# Ordinarily, an error in user code invoked by the reactor aborts the
|
59
|
+
# run.
|
60
|
+
#
|
61
|
+
def obsolete_test_unhandled_error
|
62
|
+
assert_raises( RuntimeError ) {
|
63
|
+
EM.run {
|
64
|
+
EM.add_timer(0) {raise "AAA"}
|
65
|
+
}
|
66
|
+
}
|
67
|
+
|
68
|
+
end
|
69
|
+
|
70
|
+
def obsolete_test_handled_error
|
71
|
+
err = nil
|
72
|
+
EM.run {
|
73
|
+
EM.set_runtime_error_hook {
|
74
|
+
err = true
|
75
|
+
EM.stop
|
76
|
+
}
|
77
|
+
EM.add_timer(0) {raise "AAA"}
|
78
|
+
}
|
79
|
+
assert err
|
80
|
+
end
|
81
|
+
end
|
82
|
+
|