summaryrefslogtreecommitdiff
path: root/test/win32ole/test_err_in_callback.rb
blob: 422fb3128848e701176c2562f0d5da72f9e55c3d (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
#
# test Win32OLE avoids cfp consistency error when the exception raised
# in WIN32OLE_EVENT handler block. [ruby-dev:35450]
#

begin
  require 'win32ole'
rescue LoadError
end
if defined?(WIN32OLE)
  require 'mkmf'
  require 'test/unit'
  require 'tmpdir'
  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.join(File.dirname(__FILE__), "err_in_callback.rb")
      end
    end

    def available_adodb?
      begin
        db = WIN32OLE.new('ADODB.Connection')
      rescue WIN32OLERuntimeError
        return false
      end
      return true
    end

    def test_err_in_callback
      skip "'ADODB.Connection' is not available" unless available_adodb?
      if @ruby
        Dir.mktmpdir do |tmpdir|
          logfile = File.join(tmpdir, "test_err_in_callback.log")
          cmd = "#{@ruby} -v #{@iopt} #{@script} > #{logfile.gsub(%r(/), '\\')} 2>&1"
          result = system(cmd)
          p [result, cmd]
          str = ""
          open(logfile) {|ifs|
            str = ifs.read
          }
          assert_match(/NameError/, str)
        end
      end
    end
  end
end