summaryrefslogtreecommitdiff
path: root/sample/timeout.rb
diff options
context:
space:
mode:
authornobu <nobu@b2dd03c8-39d4-4d8f-98ff-823fe69b080e>2010-03-11 21:37:16 +0000
committernobu <nobu@b2dd03c8-39d4-4d8f-98ff-823fe69b080e>2010-03-11 21:37:16 +0000
commit831eb93069492c82fa997287c77ca8d9f2ad8668 (patch)
treebc0a3451b86bac8f215721f9ba96acca75e6b1bd /sample/timeout.rb
parentebfe278914d74595a02e0bbd9bbcfb265967dcc3 (diff)
* sample/timeout.rb: split from lib/timeout.rb.
git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/trunk@26877 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
Diffstat (limited to 'sample/timeout.rb')
-rw-r--r--sample/timeout.rb42
1 files changed, 42 insertions, 0 deletions
diff --git a/sample/timeout.rb b/sample/timeout.rb
new file mode 100644
index 0000000000..2870ddb239
--- /dev/null
+++ b/sample/timeout.rb
@@ -0,0 +1,42 @@
+require 'timeout'
+
+def progress(n = 5)
+ n.times {|i| print i; STDOUT.flush; sleep 1; i+= 1}
+ puts "never reach"
+end
+
+p timeout(5) {
+ 45
+}
+p timeout(5, TimeoutError) {
+ 45
+}
+p timeout(nil) {
+ 54
+}
+p timeout(0) {
+ 54
+}
+begin
+ timeout(5) {progress}
+rescue => e
+ puts e.message
+end
+begin
+ timeout(3) {
+ begin
+ timeout(5) {progress}
+ rescue => e
+ puts "never reach"
+ end
+ }
+rescue => e
+ puts e.message
+end
+class MyTimeout < StandardError
+end
+begin
+ timeout(2, MyTimeout) {progress}
+rescue MyTimeout => e
+ puts e.message
+end