The Perl Toolchain Summit needs more sponsors. If your company depends on Perl, please support this very important event.
#!/usr/bin/perl

use strict;
use warnings;

my     $tests = 26;
use     Test::More;
require Test::NoWarnings;

use     Spreadsheet::Read;
my $parser = Spreadsheet::Read::parses ("sc") or
    plan skip_all => "No SquirelCalc parser found";

sub ReadDataStream {
    my $file = shift;
    open my $fh, "<", $file or return undef;
    ReadData ($fh, parser => "sc", @_);
    } # ReadDataStream

{   my $ref;
    $ref = ReadDataStream ("no_such_file.sc");
    ok (!defined $ref, "Nonexistent file");
    $ref = ReadDataStream ("files/empty.sc");
    ok (!defined $ref, "Empty file");
    }

my $content;
{   local $/;
    open my $sc, "<", "files/test.sc" or die "files/test.sc: $!\n";
    binmode $sc;
    $content = <$sc>;
    close   $sc;
    isnt ($content, undef, "Content is defined");
    isnt ($content, "",    "Content is filled");
    }

foreach my $clip (0, 2) {
    my $sc;
    ok ($sc = ReadDataStream ("files/test.sc", clip => $clip),
	"Read/Parse sc file ".($clip?"clipped":"unclipped"));

    ok (1, "Base values");
    is (ref $sc,			"ARRAY",	"Return type");
    is ($sc->[0]{type},		"sc",		"Spreadsheet type");
    is ($sc->[0]{sheets},		1,		"Sheet count");
    is (ref $sc->[0]{sheet},	"HASH",		"Sheet list");
    is (scalar keys %{$sc->[0]{sheet}},
				    1,		"Sheet list count");
    is ($sc->[0]{version}, $Spreadsheet::Read::VERSION, "Parser version");

    is ($sc->[1]{maxcol},		10 - $clip,	"Columns");
    is ($sc->[1]{maxrow},		28 - $clip,	"Rows");
    is ($sc->[1]{cell}[1][22],	"  Workspace",	"Just checking one cell");
    }

unless ($ENV{AUTOMATED_TESTING}) {
    Test::NoWarnings::had_no_warnings ();
    $tests++;
    }
done_testing ($tests);