File: sub_repeat_formula.t

package info (click to toggle)
libexcel-writer-xlsx-perl 0.79-1
  • links: PTS
  • area: main
  • in suites: jessie, jessie-kfreebsd
  • size: 11,716 kB
  • ctags: 930
  • sloc: perl: 18,380; makefile: 40
file content (116 lines) | stat: -rw-r--r-- 2,816 bytes parent folder | download | duplicates (3)
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
###############################################################################
#
# Tests for Excel::Writer::XLSX::Worksheet methods.
#
# reverse ('(c)'), April 2011, John McNamara, jmcnamara@cpan.org
#

use lib 't/lib';
use TestFunctions '_new_worksheet';
use strict;
use warnings;

use Test::More tests => 5;

###############################################################################
#
# Tests setup.
#
my $expected;
my $got;
my $caption;
my $formula;
my $row;
my $col;
my $worksheet = _new_worksheet(\$got);
my $format    = undef;


###############################################################################
#
# Test the store_formula/repeat_formula methods.
#
$caption  = " \tWorksheet: repeat_formula()";
$expected = 'SUM(A1:A10)';
$row      = 1;
$col      = 0;

$formula = $worksheet->store_formula( '=SUM(A1:A10)' );
$worksheet->repeat_formula( $row, $col, $formula, $format );

$got = $worksheet->{_table}->{$row}->{$col}->[1];

is( $got, $expected, $caption );


###############################################################################
#
# Test the store_formula/repeat_formula methods.
#
$caption  = " \tWorksheet: repeat_formula()";
$expected = 'SUM(A2:A10)';
$row      = 2;
$col      = 0;

$formula = $worksheet->store_formula( '=SUM(A1:A10)' );
$worksheet->repeat_formula( $row, $col, $formula, $format, 'A1', 'A2' );

$got = $worksheet->{_table}->{$row}->{$col}->[1];

is( $got, $expected, $caption );


###############################################################################
#
# Test the store_formula/repeat_formula methods.
#
$caption  = " \tWorksheet: repeat_formula()";
$expected = 'SUM(A2:A10)';
$row      = 3;
$col      = 0;

$formula = $worksheet->store_formula( '=SUM(A1:A10)' );
$worksheet->repeat_formula( $row, $col, $formula, $format, qr/^A1$/, 'A2' );

$got = $worksheet->{_table}->{$row}->{$col}->[1];

is( $got, $expected, $caption );


###############################################################################
#
# Test the store_formula/repeat_formula methods.
#
$caption  = " \tWorksheet: repeat_formula()";
$expected = 'A2+A2';
$row      = 4;
$col      = 0;

$formula = $worksheet->store_formula( 'A1+A1' );
$worksheet->repeat_formula( $row, $col, $formula, $format, ('A1', 'A2') x 2 );

$got = $worksheet->{_table}->{$row}->{$col}->[1];

is( $got, $expected, $caption );


###############################################################################
#
# Test the store_formula/repeat_formula methods.
#
$caption  = " \tWorksheet: repeat_formula()";
$expected = 'A10 + SIN(A10)';
$row      = 5;
$col      = 0;

$formula = $worksheet->store_formula( 'A1 + SIN(A1)' );
$worksheet->repeat_formula( $row, $col, $formula, $format, (qr/^A1$/, 'A10') x 2 );

$got = $worksheet->{_table}->{$row}->{$col}->[1];

is( $got, $expected, $caption );


__END__