###############################################################################
#
# Tests the output of Excel::Writer::XLSX against Excel generated files.
#
# reverse('©'), January 2011, John McNamara, jmcnamara@cpan.org
#
use lib 't/lib';
use TestFunctions qw(_compare_xlsx_files _is_deep_diff);
use strict;
use warnings;
use Test::More tests => 1;
###############################################################################
#
# Tests setup.
#
my $filename = 'repeat05.xlsx';
my $dir = 't/regression/';
my $got_filename = $dir . $filename;
my $exp_filename = $dir . 'xlsx_files/' . $filename;
my $ignore_members = [
qw(
xl/printerSettings/printerSettings1.bin
xl/printerSettings/printerSettings2.bin
xl/worksheets/_rels/sheet1.xml.rels
xl/worksheets/_rels/sheet3.xml.rels
)
];
my $ignore_elements = {
'[Content_Types].xml' => ['<Default Extension="bin"'],
'xl/worksheets/sheet1.xml' => ['<pageMargins', '<pageSetup'],
'xl/worksheets/sheet3.xml' => ['<pageMargins', '<pageSetup'],
};
###############################################################################
#
# Test the creation of a simple Excel::Writer::XLSX file with repeat rows and
# cols on more than one worksheet.
#
use Excel::Writer::XLSX;
my $workbook = Excel::Writer::XLSX->new( $got_filename );
my $worksheet1 = $workbook->add_worksheet();
my $worksheet2 = $workbook->add_worksheet();
my $worksheet3 = $workbook->add_worksheet();
$worksheet1->repeat_rows( 0 );
$worksheet3->repeat_rows( 2, 3 );
$worksheet3->repeat_columns( 'B:F' );
$worksheet1->write( 'A1', 'Foo' );
$workbook->close();
###############################################################################
#
# Compare the generated and existing Excel files.
#
my ( $got, $expected, $caption ) = _compare_xlsx_files(
$got_filename,
$exp_filename,
$ignore_members,
$ignore_elements,
);
_is_deep_diff( $got, $expected, $caption );
###############################################################################
#
# Cleanup.
#
unlink $got_filename;
__END__