2015-12-16 00:07:31 -05:00
|
|
|
# frozen_string_literal: false
|
2006-05-01 05:05:08 -04:00
|
|
|
# This is test script to check that WIN32OLE should convert nil to VT_EMPTY in second try.
|
|
|
|
# [ruby-talk:137054]
|
|
|
|
begin
|
|
|
|
require 'win32ole'
|
|
|
|
rescue LoadError
|
|
|
|
end
|
|
|
|
require 'test/unit'
|
2006-05-06 19:40:08 -04:00
|
|
|
|
2006-05-01 05:05:08 -04:00
|
|
|
if defined?(WIN32OLE)
|
|
|
|
class TestNIL2VT_EMPTY < Test::Unit::TestCase
|
|
|
|
def setup
|
|
|
|
fs = WIN32OLE.new('Scripting.FileSystemObject')
|
|
|
|
@path = fs.GetFolder(".").path
|
|
|
|
end
|
|
|
|
def test_openSchema
|
|
|
|
con = nil
|
|
|
|
begin
|
|
|
|
con = WIN32OLE.new('ADODB.Connection')
|
|
|
|
con.connectionString = "Provider=MSDASQL;Extended Properties="
|
|
|
|
con.connectionString +="\"DRIVER={Microsoft Text Driver (*.txt; *.csv)};DBQ=#{@path}\""
|
|
|
|
con.open
|
|
|
|
rescue
|
|
|
|
con = nil
|
|
|
|
end
|
|
|
|
if con
|
|
|
|
rs = con.openSchema(4, [nil,nil,"DUMMY", "TABLE"])
|
|
|
|
assert(rs)
|
|
|
|
assert_equal("_Recordset", rs.ole_type.name)
|
2009-03-05 22:56:38 -05:00
|
|
|
|
2007-01-19 03:22:45 -05:00
|
|
|
rs = con.openSchema(4, [WIN32OLE_VARIANT::Empty, WIN32OLE_VARIANT::Empty, "DUMMY", "TABLE"])
|
|
|
|
assert(rs)
|
|
|
|
assert_equal("_Recordset", rs.ole_type.name)
|
2006-05-01 05:05:08 -04:00
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|