# -*- coding: utf-8 -*- ########################################################################## # test_52_name_print_titles.rb # # Tests for the Excel EXTERNSHEET and NAME records created by print_are().. # # reverse('ゥ'), September 2008, John McNamara, jmcnamara@cpan.org # # original written in Perl by John McNamara # converted to Ruby by Hideo Nakamura, cxn03651@msj.biglobe.ne.jp # ######################################################################### require 'helper' require 'stringio' class TC_Name_Print_Titles < Test::Unit::TestCase def setup @test_file = StringIO.new @workbook = WriteExcel.new(@test_file) @workbook.not_using_tmpfile end def teardown @workbook.close end def test_repeat_rows_for_top_row_only worksheet1 = @workbook.add_worksheet worksheet1.repeat_rows(0) # Test the EXTERNSHEET record. @workbook.calculate_extern_sizes @workbook.store_externsheet target = [%w( 17 00 08 00 01 00 00 00 00 00 00 00 ).join('')].pack('H*') caption = " \tExternsheet" result = _unpack_externsheet(@workbook.data) target = _unpack_externsheet(target) assert_equal(target, result) # Test the NAME record. @workbook.clear_data_for_test @workbook.store_names target = [%w( 18 00 1B 00 20 00 00 01 0B 00 00 00 01 00 00 00 00 00 00 07 3B 00 00 00 00 00 00 00 00 FF 00 ).join('')].pack('H*') caption = " \t+ Name repeats ( Sheet1!1:1 )"; result = _unpack_name(@workbook.data) target = _unpack_name(target) assert_equal(target, result) end def test_repeat_rows_for_top_10_rows worksheet1 = @workbook.add_worksheet worksheet1.repeat_rows(0, 9) # Test the EXTERNSHEET record. @workbook.calculate_extern_sizes @workbook.store_externsheet target = [%w( 17 00 08 00 01 00 00 00 00 00 00 00 ).join('')].pack('H*') caption = " \tExternsheet" result = _unpack_externsheet(@workbook.data) target = _unpack_externsheet(target) assert_equal(target, result) # Test the NAME record. @workbook.clear_data_for_test @workbook.store_names target = [%w( 18 00 1B 00 20 00 00 01 0B 00 00 00 01 00 00 00 00 00 00 07 3B 00 00 00 00 09 00 00 00 FF 00 ).join('')].pack('H*') caption = " \t+ Name repeats ( Sheet1!1:10 )"; result = _unpack_name(@workbook.data) target = _unpack_name(target) assert_equal(target, result) end def test_repeat_columns_for_a_single_column worksheet1 = @workbook.add_worksheet worksheet1.repeat_columns(0) # Test the EXTERNSHEET record. @workbook.calculate_extern_sizes @workbook.store_externsheet target = [%w( 17 00 08 00 01 00 00 00 00 00 00 00 ).join('')].pack('H*') caption = " \tExternsheet" result = _unpack_externsheet(@workbook.data) target = _unpack_externsheet(target) assert_equal(target, result) # Test the NAME record. @workbook.clear_data_for_test @workbook.store_names target = [%w( 18 00 1B 00 20 00 00 01 0B 00 00 00 01 00 00 00 00 00 00 07 3B 00 00 00 00 FF FF 00 00 00 00 ).join('')].pack('H*') caption = " \t+ Name repeats ( Sheet1!A:A )"; result = _unpack_name(@workbook.data) target = _unpack_name(target) assert_equal(target, result) end def test_repeat_columns_for_a_single_column_A1_notation worksheet1 = @workbook.add_worksheet worksheet1.repeat_columns('A:A') # Test the EXTERNSHEET record. @workbook.calculate_extern_sizes @workbook.store_externsheet target = [%w( 17 00 08 00 01 00 00 00 00 00 00 00 ).join('')].pack('H*') caption = " \tExternsheet" result = _unpack_externsheet(@workbook.data) target = _unpack_externsheet(target) assert_equal(target, result) # Test the NAME record. @workbook.clear_data_for_test @workbook.store_names target = [%w( 18 00 1B 00 20 00 00 01 0B 00 00 00 01 00 00 00 00 00 00 07 3B 00 00 00 00 FF FF 00 00 00 00 ).join('')].pack('H*') caption = " \t+ Name repeats ( Sheet1!A:A )"; result = _unpack_name(@workbook.data) target = _unpack_name(target) assert_equal(target, result) end def test_repeat_columns_for_a_10_columns worksheet1 = @workbook.add_worksheet worksheet1.repeat_columns(0, 9) # Test the EXTERNSHEET record. @workbook.calculate_extern_sizes @workbook.store_externsheet target = [%w( 17 00 08 00 01 00 00 00 00 00 00 00 ).join('')].pack('H*') caption = " \tExternsheet" result = _unpack_externsheet(@workbook.data) target = _unpack_externsheet(target) assert_equal(target, result) # Test the NAME record. @workbook.clear_data_for_test @workbook.store_names target = [%w( 18 00 1B 00 20 00 00 01 0B 00 00 00 01 00 00 00 00 00 00 07 3B 00 00 00 00 FF FF 00 00 09 00 ).join('')].pack('H*') caption = " \t+ Name repeats ( Sheet1!A:J )"; result = _unpack_name(@workbook.data) target = _unpack_name(target) assert_equal(target, result) end def test_repeat_columns_for_a_10_columns_A1_notation worksheet1 = @workbook.add_worksheet worksheet1.repeat_columns('A:J') # Test the EXTERNSHEET record. @workbook.calculate_extern_sizes @workbook.store_externsheet target = [%w( 17 00 08 00 01 00 00 00 00 00 00 00 ).join('')].pack('H*') caption = " \tExternsheet" result = _unpack_externsheet(@workbook.data) target = _unpack_externsheet(target) assert_equal(target, result) # Test the NAME record. @workbook.clear_data_for_test @workbook.store_names target = [%w( 18 00 1B 00 20 00 00 01 0B 00 00 00 01 00 00 00 00 00 00 07 3B 00 00 00 00 FF FF 00 00 09 00 ).join('')].pack('H*') caption = " \t+ Name repeats ( Sheet1!A:J )"; result = _unpack_name(@workbook.data) target = _unpack_name(target) assert_equal(target, result) end def test_repeat_rows_on_multiple_sheets worksheet1 = @workbook.add_worksheet worksheet2 = @workbook.add_worksheet worksheet3 = @workbook.add_worksheet worksheet1.repeat_rows(0, 1) worksheet2.repeat_rows(3, 4) worksheet3.repeat_rows(6, 7) # Test the EXTERNSHEET record. @workbook.calculate_extern_sizes @workbook.store_externsheet target = [%w( 17 00 14 00 03 00 00 00 00 00 00 00 00 00 01 00 01 00 00 00 02 00 02 00 ).join('')].pack('H*') caption = " \tExternsheet" result = _unpack_externsheet(@workbook.data) target = _unpack_externsheet(target) assert_equal(target, result) # Test the NAME record. @workbook.clear_data_for_test @workbook.store_names target = [%w( 18 00 1B 00 20 00 00 01 0B 00 00 00 01 00 00 00 00 00 00 07 3B 00 00 00 00 01 00 00 00 FF 00 18 00 1B 00 20 00 00 01 0B 00 00 00 02 00 00 00 00 00 00 07 3B 01 00 03 00 04 00 00 00 FF 00 18 00 1B 00 20 00 00 01 0B 00 00 00 03 00 00 00 00 00 00 07 3B 02 00 06 00 07 00 00 00 FF 00 ).join('')].pack('H*') caption = " \t+ Name repeats ( Sheet1!1:2, Sheet2!4:5, Sheet3!7:8 )"; result = _unpack_name(@workbook.data) target = _unpack_name(target) assert_equal(target, result) end def test_repeat_rows_on_multiple_sheets_with_sheets_spaced_out worksheet1 = @workbook.add_worksheet worksheet2 = @workbook.add_worksheet worksheet3 = @workbook.add_worksheet worksheet4 = @workbook.add_worksheet worksheet5 = @workbook.add_worksheet worksheet1.repeat_rows(0, 1) worksheet3.repeat_rows(3, 4) worksheet5.repeat_rows(6, 7) # Test the EXTERNSHEET record. @workbook.calculate_extern_sizes @workbook.store_externsheet target = [%w( 17 00 14 00 03 00 00 00 00 00 00 00 00 00 02 00 02 00 00 00 04 00 04 00 ).join('')].pack('H*') caption = " \tExternsheet" result = _unpack_externsheet(@workbook.data) target = _unpack_externsheet(target) assert_equal(target, result) # Test the NAME record. @workbook.clear_data_for_test @workbook.store_names target = [%w( 18 00 1B 00 20 00 00 01 0B 00 00 00 01 00 00 00 00 00 00 07 3B 00 00 00 00 01 00 00 00 FF 00 18 00 1B 00 20 00 00 01 0B 00 00 00 03 00 00 00 00 00 00 07 3B 01 00 03 00 04 00 00 00 FF 00 18 00 1B 00 20 00 00 01 0B 00 00 00 05 00 00 00 00 00 00 07 3B 02 00 06 00 07 00 00 00 FF 00 ).join('')].pack('H*') caption = " \t+ Name repeats ( Sheet1!1:2, Sheet3!4:5, Sheet5!7:8 )"; result = _unpack_name(@workbook.data) target = _unpack_name(target) assert_equal(target, result) end def test_repeat_rows_and_repeat_columns_together worksheet1 = @workbook.add_worksheet worksheet1.repeat_rows(1, 2) worksheet1.repeat_columns(3, 4) # Test the EXTERNSHEET record. @workbook.calculate_extern_sizes @workbook.store_externsheet target = [%w( 17 00 08 00 01 00 00 00 00 00 00 00 ).join('')].pack('H*') caption = " \tExternsheet" result = _unpack_externsheet(@workbook.data) target = _unpack_externsheet(target) assert_equal(target, result) # Test the NAME record. @workbook.clear_data_for_test @workbook.store_names target = [%w( 18 00 2A 00 20 00 00 01 1A 00 00 00 01 00 00 00 00 00 00 07 29 17 00 3B 00 00 00 00 FF FF 03 00 04 00 3B 00 00 01 00 02 00 00 00 FF 00 10 ).join('')].pack('H*') caption = " \t+ Name repeats ( Sheet1!2:3, Sheet1!D:E )"; result = _unpack_name(@workbook.data) target = _unpack_name(target) assert_equal(target, result) end ############################################################################### # # _unpack_externsheet() # # Unpack the EXTERNSHEET recordfor easier comparison. # def _unpack_externsheet(data) externsheet = Hash.new externsheet['record'] = data[0, 2].unpack('v')[0] data[0, 2] = '' externsheet['length'] = data[0, 2].unpack('v')[0] data[0, 2] = '' externsheet['count'] = data[0, 2].unpack('v')[0] data[0, 2] = '' externsheet['array'] = []; externsheet['count'].times do externsheet['array'] << data[0, 6].unpack('vvv') data[0, 6] = '' end externsheet end ############################################################################### # # _unpack_name() # # Unpack 1 or more NAME structures into a AoH for easier comparison. # def _unpack_name(data) names = Array.new while data.length > 0 name = Hash.new name['record'] = data[0, 2].unpack('v')[0] data[0, 2] = '' name['length'] = data[0, 2].unpack('v')[0] data[0, 2] = '' name['flags'] = data[0, 2].unpack('v')[0] data[0, 2] = '' name['shortcut'] = data[0, 1].unpack('C')[0] data[0, 1] = '' name['str_len'] = data[0, 1].unpack('C')[0] data[0, 1] = '' name['formula_len'] = data[0, 2].unpack('v')[0] data[0, 2] = '' name['itals'] = data[0, 2].unpack('v')[0] data[0, 2] = '' name['sheet_index'] = data[0, 2].unpack('v')[0] data[0, 2] = '' name['menu_len'] = data[0, 1].unpack('C')[0] data[0, 1] = '' name['desc_len'] = data[0, 1].unpack('C')[0] data[0, 1] = '' name['help_len'] = data[0, 1].unpack('C')[0] data[0, 1] = '' name['status_len'] = data[0, 1].unpack('C')[0] data[0, 1] = '' name['encoding'] = data[0, 1].unpack('C')[0] data[0, 1] = '' # Decode the individual flag fields. flag = Hash.new flag['hidden'] = name['flags'] & 0x0001 flag['function'] = name['flags'] & 0x0002 flag['vb'] = name['flags'] & 0x0004 flag['macro'] = name['flags'] & 0x0008 flag['complex'] = name['flags'] & 0x0010 flag['builtin'] = name['flags'] & 0x0020 flag['group'] = name['flags'] & 0x0FC0 flag['binary'] = name['flags'] & 0x1000 name['flags'] = flag # Decode the string part of the NAME structure. if name['encoding'] == 1 # UTF-16 name. Leave in hex. name['string'] = data[0, 2 * name['str_len']].unpack('H*')[0].upcase data[0, 2 * name['str_len']] = '' elsif flag['builtin'] != 0 # 1 digit builtin name. Leave in hex. name['string'] = data[0, name['str_len']].unpack('H*')[0].upcase data[0, name['str_len']] = '' else # ASCII name. name['string'] = data[0, name['str_len']].unpack('C*').pack('C*') data[0, name['str_len']] = '' end # Keep the formula as a hex string. name['formula'] = data[0, name['formula_len']].unpack('H*')[0].upcase data[0, name['formula_len']] = '' names << name end names end def assert_hash_equal?(result, target) assert_equal(result.keys.sort, target.keys.sort) result.each_key do |key| assert_equal(result[key], target[key]) end end end