mirror of
https://github.com/ruby/ruby.git
synced 2022-11-09 12:17:21 -05:00
* 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
This commit is contained in:
parent
ebfe278914
commit
831eb93069
4 changed files with 48 additions and 23 deletions
42
sample/timeout.rb
Normal file
42
sample/timeout.rb
Normal file
|
|
@ -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
|
||||
Loading…
Add table
Add a link
Reference in a new issue