1
0
Fork 0
mirror of https://github.com/ruby/ruby.git synced 2022-11-09 12:17:21 -05:00
ruby--ruby/test/win32ole/test_err_in_callback.rb
suke 73412af59a * test/win32ole/test_err_in_callback.rb (teardown): get rid
of infinite loop.


git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/trunk@19296 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
2008-09-11 11:15:43 +00:00

84 lines
2.2 KiB
Ruby

#
# test Win32OLE avoids cfp consistency error when the exception raised
# in WIN32OLE_EVENT handler block. [ruby-dev:35450]
#
begin
require 'win32ole'
rescue LoadError
end
require 'rbconfig'
if defined?(WIN32OLE)
require 'mkmf'
require 'test/unit'
class TestErrInCallBack < Test::Unit::TestCase
def setup
@ruby = nil
if File.exist?("./" + CONFIG["RUBY_INSTALL_NAME"] + CONFIG["EXEEXT"])
sep = File::ALT_SEPARATOR || "/"
@ruby = "." + sep + CONFIG["RUBY_INSTALL_NAME"]
@iopt = $:.map {|e|
" -I " + e
}.join("")
@script = File.dirname(__FILE__) + "/err_in_callback.rb"
@param = create_temp_html
@param = "file:///" + @param.gsub(/\\/, '/')
end
end
def create_temp_html
fso = WIN32OLE.new('Scripting.FileSystemObject')
@dummy_file = fso.GetTempName + ".html"
cfolder = fso.getFolder(".")
@str = "This is test HTML file for Win32OLE (#{Time.now})"
f = cfolder.CreateTextFile(@dummy_file)
f.writeLine("<html><body><div id='str'>#{@str}</div></body></html>")
f.close
@f = @dummy_file
dummy_path = cfolder.path + "\\" + @dummy_file
dummy_path
end
def test_err_in_callback
if @ruby
cmd = "#{@ruby} -v #{@iopt} #{@script} #{@param} > test_err_in_callback.log 2>&1"
system(cmd)
str = ""
open("test_err_in_callback.log") {|ifs|
str = ifs.read
}
assert_match(/NameError/, str)
end
end
def ie_quit
WIN32OLE_EVENT.message_loop
sh = WIN32OLE.new('Shell.Application')
sh.windows.each do |w|
i = 0
begin
i = i + 1
next if i > 100
WIN32OLE_EVENT.message_loop
sleep 0.1
next if /#{@dummy_file}/ !~ w.locationURL
e = w.document.all.item("str")
if e && e.innerHTML == @str
w.quit
WIN32OLE_EVENT.message_loop
sleep 0.2
break
end
rescue
retry
end
end
end
def teardown
ie_quit
File.unlink(@f)
File.unlink("test_err_in_callback.log")
end
end
end