]> git.vpit.fr Git - perl/modules/Variable-Magic.git/blob - t/30-scalar.t
4189ee5dfab5491f4653232442c1f7eccf7ef6e2
[perl/modules/Variable-Magic.git] / t / 30-scalar.t
1 #!perl -T
2
3 use strict;
4 use warnings;
5
6 use Config qw<%Config>;
7
8 use Test::More tests => (2 * 14 + 2) + 2 * (2 * 8 + 4) + 5 + 1;
9
10 use Variable::Magic qw<wizard cast dispell>;
11
12 use lib 't/lib';
13 use Variable::Magic::TestWatcher;
14
15 my $is_5130_release = ("$]" == 5.013 && !$Config{git_describe}) ? 1 : 0;
16
17 my $wiz = init_watcher
18         [ qw<get set len clear free copy dup local fetch store exists delete> ],
19         'scalar';
20
21 my $n = int rand 1000;
22 my $a = $n;
23
24 watch { cast $a, $wiz } { }, 'cast';
25
26 my $b;
27 # $b has to be set inside the block for the test to pass on 5.8.3 and lower
28 watch { $b = $a } { get => 1 }, 'assign to';
29 is $b, $n, 'scalar: assign to correctly';
30
31 $b = watch { "X${a}Y" } { get => 1 }, 'interpolate';
32 is $b, "X${n}Y", 'scalar: interpolate correctly';
33
34 $b = watch { \$a } { }, 'reference';
35
36 watch { $a = 123 } { set => 1 }, 'assign to';
37
38 watch { ++$a } { get => 1, set => 1 }, 'increment';
39
40 watch { --$a } { get => 1, set => 1 }, 'decrement';
41
42 watch { $a *= 1.5 } { get => 1, set => 1 }, 'multiply in place';
43
44 watch { $a /= 1.5 } { get => 1, set => 1 }, 'divide in place';
45
46 watch {
47  my $b = $n;
48  watch { cast $b, $wiz } { }, 'cast 2';
49 } { free => 1 }, 'scope end';
50
51 watch { undef $a } { set => 1 }, 'undef';
52
53 watch { dispell $a, $wiz } { }, 'dispell';
54
55 # Array element
56
57 my @a = (7, 8, 9);
58
59 watch { cast $a[1], $wiz } { }, 'array element: cast';
60
61 watch { $a[1] = 6 } { set => 1 }, 'array element: set';
62
63 $b = watch { $a[1] } { get => ($is_5130_release ? 2 : 1) },'array element: get';
64 is $b, 6, 'scalar: array element: get correctly';
65
66 watch { $a[0] = 5 } { }, 'array element: set other';
67
68 $b = watch { $a[2] } { }, 'array element: get other';
69 is $b, 9, 'scalar: array element: get other correctly';
70
71 $b = watch { exists $a[1] } { }, 'array element: exists';
72 is $b, 1, 'scalar: array element: exists correctly';
73
74 # $b has to be set inside the block for the test to pass on 5.8.3 and lower
75 watch { $b = delete $a[1] } { get => 1, free => ("$]" > 5.008_005 ? 1 : 0) },
76                             'array element: delete';
77 is $b, 6, 'scalar: array element: delete correctly';
78
79 watch { $a[1] = 4 } { }, 'array element: set after delete';
80
81 # Hash element
82
83 my %h = (a => 7, b => 8);
84
85 watch { cast $h{b}, $wiz } { }, 'hash element: cast';
86
87 watch { $h{b} = 6 } { set => 1 }, 'hash element: set';
88
89 $b = watch { $h{b} } { get => ($is_5130_release ? 2 : 1) }, 'hash element: get';
90 is $b, 6, 'scalar: hash element: get correctly';
91
92 watch { $h{a} = 5 } { }, 'hash element: set other';
93
94 $b = watch { $h{a} } { }, 'hash element: get other';
95 is $b, 5, 'scalar: hash element: get other correctly';
96
97 $b = watch { exists $h{b} } { }, 'hash element: exists';
98 is $b, 1, 'scalar: hash element: exists correctly';
99
100 $b = watch { delete $h{b} } { get => 1, free => 1 }, 'hash element: delete';
101 is $b, 6, 'scalar: hash element: delete correctly';
102
103 watch { $h{b} = 4 } { }, 'hash element: set after delete';
104
105 SKIP: {
106  unless (do { local $@; eval { require Tie::Array; 1 } }) {
107   skip 'Tie::Array required to test clear magic on tied array values' => 5;
108  }
109  defined and diag "Using Tie::Array $_" for $Tie::Array::VERSION;
110
111  tie my @a, 'Tie::StdArray';
112  $a[0] = $$;
113  $a[1] = -$$;
114
115  eval {
116   cast @a, wizard copy => sub { cast $_[3], $wiz; () };
117  };
118  is $@, '', 'cast copy magic on tied array';
119
120  watch { delete $a[0] } [ qw<clear free> ],
121                         'delete from tied array in void context';
122
123  $b = watch { delete $a[1] } [ qw<get clear free> ],
124                              'delete from tied array in scalar context';
125 }