forked from Raku/roast
-
Notifications
You must be signed in to change notification settings - Fork 0
/
eval.t
117 lines (94 loc) · 2.88 KB
/
eval.t
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
117
use v6;
use nqp;
use Test;
plan 24;
# L<S29/Context/"=item EVAL">
=begin pod
Tests for the EVAL() builtin
=end pod
# EVAL should evaluate the code in the lexical scope of EVAL's caller
{
sub make_eval_closure {
my $a = 5; #OK not used
return sub ($s) {
EVAL $s
};
};
is(make_eval_closure().('$a'), 5, 'EVAL runs code in the proper lexical scope');
}
is(EVAL('5'), 5, 'simple EVAL works and returns the value');
my $foo = 1234;
is(EVAL('$foo'), $foo, 'simple EVAL using variable defined outside');
# traps die?
dies-ok {EVAL('die; 1')}, "EVAL does not trap die";
dies-ok {EVAL '1 1)'}, "EVAL throws on syntax error";
dies-ok {EVAL 'use Poison; 1'}, "EVAL dies on fatal use";
# L<S04/Exception handlers/Perl 6's EVAL function only evaluates strings, not blocks.>
dies-ok({EVAL {; 42} }, 'block EVAL is gone');
# RT #63978, EVAL didn't work in methods
{
class EvalTester1 {
method e($s) { EVAL $s };
}
is EvalTester1.e('5'), 5, 'EVAL works inside class methods';
is EvalTester1.new.e('5'), 5, 'EVAL works inside instance methods';
}
{
my $x = 5;
class EvalTester2 {
method e($s) { EVAL "$s + \$x" };
}
is EvalTester2.e('1'), 6,
'EVAL works inside class methods, with outer lexicals';
is EvalTester2.new.e('1'), 6,
'EVAL works inside instance methods, with outer lexicals';
}
#?rakudo skip 'EVAL(Buf) RT #122256'
#?niecza skip 'Unable to resolve method encode in class Str'
{
is EVAL("'møp'".encode('UTF-8')), 'møp', 'EVAL(Buf)';
is "'møp'".encode('UTF-8').EVAL, 'møp', 'Buf.EVAL';
}
{
is EVAL(88), 88, 'EVAL of non-string works';
is 88.EVAL, 88, '.EVAL of non-string works';
my $number = 2;
is EVAL($number), $number, 'EVAL of non-string variable works';
is $number.EVAL, $number, '.EVAL of non-string variable works';
}
# RT #77646
{
my $x = 0;
EVAL '$x++' for 1..4;
is $x, 4, 'can execute the same EVAL multiple times, without surrounding block';
}
# RT #112472
#?niecza todo "No :lang argument yet..."
{
try EVAL(:lang<rt112472>, '1');
ok "$!" ~~ / 'rt112472' /, 'EVAL in bogus language mentions the language';
}
# RT #115344
my $rt115344 = 115344;
#?niecza skip 'method form of EVAL does not see outer lexicals'
is('$rt115344'.EVAL, $rt115344, 'method form of EVAL sees outer lexicals');
# RT #115774
#?niecza skip "int NYI"
{
my int $a; EVAL('');
ok(1, "presence of low level types doesn't cause EVAL error")
}
# RT #124304
{
my \a = rand;
lives-ok { EVAL 'a' }, 'Can EVAL with a sigilless var';
is EVAL('a'), a, 'EVAL with sigilless var gives correct result';
}
# RT #128457
{
is
nqp::atkey(CompUnit::Loader.load-source(q<package Qux { BEGIN EVAL q<>; };>.encode).unit, q<$?PACKAGE>).^name,
"GLOBAL",
"EVAL's package does not leak to the surrounding compilation unit";
}
# vim: ft=perl6