use IPC::System::Simple qw(capture EXIT_ANY); use FindBin qw($Bin); use Data::Printer; use Test::More; use Try::Tiny; use IO::All; use strict; use warnings; use feature 'say'; use lib '/home/raj/perl-lib'; use Local::WriteExcel; # filenames for 2 xl files, xls & xlsx: my $xlsx_file = $Bin .'/write-excel-test-1.xlsx'; # warn $xlsx_file; my $xls_file = $Bin .'/write-excel-test-2.xls'; # warn $xlx_file; { # delete any existing xls[x] files: my @files = io($Bin)->all; # p $_->ext for @files; io($_)->unlink for grep $_->ext =~ /xls/, @files; } my @headers = qw( name dob result ); my @data = ( [ qw/bob 1975-02-01 pass/ ], [ qw/joe 1973-03-01 fail/ ], [ qw/amy 1983-11-15 pass/ ], ); # new xlsx src file ============================================================ { my $xlsx = Local::WriteExcel->new(filename => $xlsx_file); # p $xl; $xlsx->worksheet_name('data'); $xlsx->write_bold_row(\@headers); $xlsx->write_row($_) for @data; $xlsx->save(); is(-e $xlsx_file, 1, 'OK: test file 1 exists'); test_content($xlsx_file); } # new xls src file ============================================================= { my $xls = Local::WriteExcel->new(filename => $xls_file); # p $xl; try { $xls->worksheet_name('data'); } catch { # p $_; like($_, qr/^filetype must be xlsx to use worksheet_name/, 'OK: incorrect filetype for worksheet_name'); }; $xls->write_bold_row(\@headers); $xls->write_row($_) for @data; $xls->save(); is(-e $xls_file, 1, 'OK: test file 2 exists'); test_content($xls_file); } # test xls save() command with filename arg ==================================== { my $xls = Local::WriteExcel->new(filetype => 'xls'); # p $xl; $xls->write_bold_row(\@headers); $xls->write_row($_) for @data; try { $xls->save(); } catch { # p $_; like($_, qr/^cannot call save\(\) without a filename arg/, 'OK: failed to save file without filename'); }; my $test_file_3 = $Bin .'/write-excel-test-3.xls'; $xls->save($test_file_3); is(-e $test_file_3, 1, 'OK: test file 3 exists'); test_content($test_file_3); } # test xlsx save() command with filename arg ==================================== { my $xlsx = Local::WriteExcel->new(filetype => 'xlsx'); # p $xl; $xlsx->worksheet_name('data'); $xlsx->write_bold_row(\@headers); $xlsx->write_row($_) for @data; try { $xlsx->save(); } catch { # p $_; like($_, qr/^cannot call save\(\) without a filename arg/, 'OK: failed to save file without filename'); }; my $test_file_4 = $Bin .'/write-excel-test-4.xlsx'; $xlsx->save($test_file_4); is(-e $test_file_4, 1, 'OK: test file 4 exists'); test_content($test_file_4); # new xlsx file in same scope as previous (tests for persistence of xlxs_data): my $xlsx2 = Local::WriteExcel->new(filetype => 'xlsx'); # p $xl; $xlsx2->worksheet_name('data'); $xlsx2->write_bold_row(\@headers); $xlsx2->write_row($_) for @data; my $test_file_5 = $Bin .'/write-excel-test-5.xlsx'; $xlsx2->save($test_file_5); is(-e $test_file_5, 1, 'OK: test file 5 exists'); # file is unreadable if xlxs_data persists: test_content($test_file_5); } sub test_content { my $filename = shift; # p $filename; # Spreadsheet::Read doesn't support OO until >0.67 which won't intsall on Deb7 perl # my $book = ReadData($xl_file); # Can't locate object method "new" via package "Spreadsheet::Read" #my $book = Spreadsheet::Read->new($xl_file); # p $book; # my @sheets = $book->sheets; p @sheets; # Can't call method "sheets" on unblessed reference #my @rows = rows($book->[1]); # p @rows; my $row_count = 1; # for xlscat -R { # header row: my $expected = join '|', @headers; chomp( my $content = capture('xlscat', '-R'.$row_count++, $filename) ); is( $expected, $content, 'OK: row 1 headers'); } for (0..2) { # @data rows: my $expected = join '|', @{$data[$_]}; chomp( my $content = capture('xlscat', '-R'.$row_count++, $filename) ); is( $expected, $content, 'OK: row ' . ($_ + 2) . ' content'); } } done_testing(28);