#!/usr/bin/env ruby require './TestSetup' require 'test/unit' require 'rubygems' require 'rubyfb' include Rubyfb class RowTest < Test::Unit::TestCase CURDIR = "#{Dir.getwd}" DB_FILE = "#{CURDIR}#{File::SEPARATOR}row_unit_test.fdb" def setup puts "#{self.class.name} started." if TEST_LOGGING if File::exist?(DB_FILE) Database.new(DB_FILE).drop(DB_USER_NAME, DB_PASSWORD) end database = Database::create(DB_FILE, DB_USER_NAME, DB_PASSWORD) @connection = database.connect(DB_USER_NAME, DB_PASSWORD) @transaction = @connection.start_transaction @results = ResultSet.new(@connection, @transaction, 'SELECT * FROM RDB$FIELDS', 3, nil) @empty = [[0, SQLType::INTEGER], [0, SQLType::INTEGER], [0, SQLType::INTEGER], [0, SQLType::INTEGER], [0, SQLType::INTEGER], [0, SQLType::INTEGER], [0, SQLType::INTEGER], [0, SQLType::INTEGER], [0, SQLType::INTEGER], [0, SQLType::INTEGER], [0, SQLType::INTEGER], [0, SQLType::INTEGER], [0, SQLType::INTEGER], [0, SQLType::INTEGER], [0, SQLType::INTEGER], [0, SQLType::INTEGER], [0, SQLType::INTEGER], [0, SQLType::INTEGER], [0, SQLType::INTEGER], [0, SQLType::INTEGER], [0, SQLType::INTEGER], [0, SQLType::INTEGER], [0, SQLType::INTEGER], [0, SQLType::INTEGER], [0, SQLType::INTEGER], [0, SQLType::INTEGER], [0, SQLType::INTEGER], [0, SQLType::INTEGER]] @connection.start_transaction do |tx| tx.execute('create table rowtest (COL01 integer, COL02 varchar(10), '\ 'COL03 integer)') tx.execute('create table all_types (col01 bigint, col02 blob, '\ 'col03 char(100), col04 date, col05 decimal(5,2), '\ 'col06 double precision, col07 float, col08 integer, '\ 'col09 numeric(10,3), col10 smallint, col11 time, '\ 'col12 timestamp, col13 varchar(23))') end @connection.start_transaction do |tx| tx.execute("insert into rowtest values (1, 'Two', 3)") stmt = Statement.new(@connection, tx, "insert into all_types values(?, ?, ?, ?, ?, ?, "\ "?, ?, ?, ?, ?, ?, ?)", 3) #stmt.execute_for([nil, nil, nil, nil, nil, nil, nil, nil, nil, nil, nil, nil, nil]) stmt.execute_for([100000, nil, 'La la la', Date.new(2005, 10, 29), 10.23, 100.751, 56.25, 12345, 19863.21, 123, Time.new, Time.new, 'The End!']) end end def teardown @results.close @transaction.rollback @connection.close if File::exist?(DB_FILE) Database.new(DB_FILE).drop(DB_USER_NAME, DB_PASSWORD) end puts "#{self.class.name} finished." if TEST_LOGGING end def test01 row = Row.new(@results, @empty, 100) assert(row.column_count == 28) assert(row.number == 100) assert(row.column_name(0) == 'RDB$FIELD_NAME') assert(row.column_alias(10) == 'RDB$FIELD_TYPE') assert(row[0] == 0) assert(row['RDB$FIELD_TYPE'] == 0) end def test02 sql = 'select COL01 one, COL02 two, COL03 three from rowtest' rows = @connection.execute_immediate(sql) data = rows.fetch count = 0 data.each do |name, value| assert(['ONE', 'TWO', 'THREE'].include?(name)) assert([1, 'Two', 3].include?(value)) count += 1 end assert(count == 3) count = 0 data.each_key do |name| assert(['ONE', 'TWO', 'THREE'].include?(name)) count += 1 end assert(count == 3) count = 0 data.each_value do |value| assert([1, 'Two', 3].include?(value)) count += 1 end assert(count == 3) assert(data.fetch('TWO') == 'Two') assert(data.fetch('FOUR', 'LALALA') == 'LALALA') assert(data.fetch('ZERO') {'NOT FOUND'} == 'NOT FOUND') begin data.fetch('FIVE') assert(false, 'Row#fetch succeeded for non-existent column name.') rescue IndexError end assert(data.has_key?('ONE')) assert(data.has_key?('TEN') == false) assert(data.has_column?('COL02')) assert(data.has_column?('COL22') == false) assert(data.has_alias?('TWO')) assert(data.has_alias?('FOUR') == false) assert(data.has_value?(3)) assert(data.has_value?('LALALA') == false) assert(data.keys.size == 3) data.keys.each do |name| assert(['ONE', 'TWO', 'THREE'].include?(name)) end assert(data.names.size == 3) data.names.each do |name| assert(['COL01', 'COL02', 'COL03'].include?(name)) end assert(data.aliases.size == 3) data.aliases.each do |name| assert(['ONE', 'TWO', 'THREE'].include?(name)) end assert(data.values.size == 3) data.values.each do |value| assert([1, 'Two', 3].include?(value)) end array = data.select {|name, value| name == 'TWO'} assert(array.size == 1) assert(array[0][0] == 'TWO') assert(array[0][1] == 'Two') array = data.to_a assert(array.size == 3) assert(array.include?(['ONE', 1])) assert(array.include?(['TWO', 'Two'])) assert(array.include?(['THREE', 3])) hash = data.to_hash assert(hash.length == 3) assert(hash['ONE'] == 1) assert(hash['TWO'] == 'Two') assert(hash['THREE'] == 3) array = data.values_at('TEN', 'TWO', 'THREE') assert(array.size == 3) assert(array.include?('Two')) assert(array.include?(3)) assert(array.include?(nil)) rows.close end def test03 results = nil row = nil begin results = @connection.execute_immediate('select * from all_types') row = results.fetch assert(row.get_base_type(0) == SQLType::BIGINT) assert(row.get_base_type(1) == SQLType::BLOB) assert(row.get_base_type(2) == SQLType::CHAR) assert(row.get_base_type(3) == SQLType::DATE) assert(row.get_base_type(4) == SQLType::DECIMAL) assert(row.get_base_type(5) == SQLType::DOUBLE) assert(row.get_base_type(6) == SQLType::FLOAT) assert(row.get_base_type(7) == SQLType::INTEGER) assert(row.get_base_type(8) == SQLType::NUMERIC) assert(row.get_base_type(9) == SQLType::SMALLINT) assert(row.get_base_type(10) == SQLType::TIME) assert(row.get_base_type(11) == SQLType::TIMESTAMP) assert(row.get_base_type(12) == SQLType::VARCHAR) ensure results.close if results != nil end end def test04 results = @transaction.execute(<<-EOSQL) SELECT CAST(5.01 AS DECIMAL(6,5)) AS "COL01", 2.2 AS "COL02", CAST(3 AS INTEGER) AS "COL03" FROM RDB$DATABASE EOSQL row = results.fetch assert_equal(-5, row.column_scale(0)) assert_equal(-1, row.column_scale(1)) assert_equal(0, row.column_scale(2)) ensure results.close if results end end