File: 42_test95-97j-2.t

package info (click to toggle)
libspreadsheet-parseexcel-perl 0.5700-1
  • links: PTS, VCS
  • area: main
  • in suites: squeeze
  • size: 1,552 kB
  • ctags: 223
  • sloc: perl: 8,703; makefile: 4
file content (118 lines) | stat: -rwxr-xr-x 2,749 bytes parent folder | download | duplicates (6)
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
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
#!perl -w

use strict;
use Test::More tests => 66;

use utf8;
use Encode qw(encode);

use Spreadsheet::ParseExcel;
use Spreadsheet::ParseExcel::FmtJapan;

my $xl   = Spreadsheet::ParseExcel->new();
my $fmtj = Spreadsheet::ParseExcel::FmtJapan->new(encoding => 'sjis');

foreach my $xls(qw(Test95J.xls Test97J.xls)){

	my $book = $xl->Parse("t/excel_files/$xls", $fmtj);
	ok $book, "load $xls";

	my $sheet = $book->worksheet(0);

	is $sheet->{Name}, 'Sheet1-ASC', '1. ASCII name';

	my @expected = (
		[ASC     => q{This Data is 'ASC Only'}],
		[Date    => q{1964/3/23}],
		[INTEGER => 12345],
		[Float   => 1.29],
		[Double  => 1234567.89012345],
		[Formula => 1246912.89012345],
		[Data    => 1234567.89],

		['BIG INTEGER'  => 123456789012],
	);

	#binmode STDOUT, ':encoding(cp932)';

	my($rmin, $rmax) = $sheet->row_range();
	my($cmin, $cmax) = $sheet->col_range();

	for my $i($rmin .. $rmax){
		for my $j($cmin .. $cmax){
			#print $sheet->get_cell($i, $j)->value, "\n";
			my $cell     = $sheet->get_cell($i, $j);
			my $got		 = $cell->value;
			my $expected = $expected[$i][$j];
			my $caption	 = "[$i, $j]";

			if ($expected =~ /\d\.\d+/) {
				_is_float($got, $expected, $caption);
			}
			else {
				is $got, $expected, $caption;
			}
		}
	}

	$sheet = $book->worksheet(1);

	is $sheet->{Name}, encode(cp932 => '漢字名'), '2. Kanji name';

	@expected = (
		[ASC     => q{This Data is 'ASC Only'}],
		[encode(cp932 => '漢字も入る') => encode(cp932 => '漢字のデータ')],
		[Date    => q{1964/3/23}],
		[INTEGER => 12345],
		[Float   => 1.29],
		[Double  => 1234567.89012345],
		[Formula => 1246912.89012345],
		[Float   => undef],
	);

	($rmin, $rmax) = $sheet->row_range();
	($cmin, $cmax) = $sheet->col_range();

	for my $i($rmin .. $rmax){
		for my $j($cmin .. $cmax){
			#print $sheet->get_cell($i, $j)->value, "\n";
			my $cell     = $sheet->get_cell($i, $j);
			my $got		 = ref($cell) ? $cell->value : $cell;
			my $expected = $expected[$i][$j];
			my $caption	 = "[$i, $j]";

			if (defined $expected && $expected =~ /\d\.\d+/) {
				_is_float($got, $expected, $caption);
			}
			else {
				is $got, $expected, $caption;
			}
		}
	}
}


###############################################################################
#
# _is_float()
#
# Helper function for float comparison. This is mainly to prevent failing tests
# on 64bit systems with extended doubles where the 128bit precision is compared
# against Excel's 64bit precision.
#
sub _is_float {

	my ( $got, $expected, $caption ) = @_;

	my $max = 1;
	$max = abs($got)	  if abs($got) > $max;
	$max = abs($expected) if abs($expected) > $max;

	if ( abs( $got - $expected ) <= 1e-15 * $max ) {
		ok( 1, $caption );
	}
	else {
		is( $got, $expected, $caption );
	}
}