drop package_ from method names
[gitmo/Package-Stash-XS.git] / t / 06-addsub.t
1 use strict;
2 use warnings;
3
4 use Test::More;
5 use Test::Fatal;
6
7 BEGIN { $^P |= 0x210 } # PERLDBf_SUBLINE
8
9 use Package::Stash;
10
11 my $foo_stash = Package::Stash->new('Foo');
12
13 # ----------------------------------------------------------------------
14 ## test adding a CODE
15
16 ok(!defined($Foo::{funk}), '... the &funk slot has not been created yet');
17
18 is(exception {
19     $foo_stash->add_symbol('&funk' => sub { "Foo::funk", __LINE__ });
20 }, undef, '... created &Foo::funk successfully');
21
22 ok(defined($Foo::{funk}), '... the &funk slot was created successfully');
23
24 {
25     no strict 'refs';
26     ok(defined &{'Foo::funk'}, '... our &funk exists');
27 }
28
29 is((Foo->funk())[0], 'Foo::funk', '... got the right value from the function');
30
31 my $line = (Foo->funk())[1];
32 { local $TODO = "need to reimplement the db stuff in xs";
33 is $DB::sub{'Foo::funk'}, sprintf "%s:%d-%d", __FILE__, $line, $line,
34     '... got the right %DB::sub value for funk default args';
35
36 $foo_stash->add_symbol(
37     '&dunk'        => sub { "Foo::dunk" },
38     filename       => "FileName",
39     first_line_num => 100,
40     last_line_num  => 199
41 );
42
43 is $DB::sub{'Foo::dunk'}, sprintf "%s:%d-%d", "FileName", 100, 199,
44     '... got the right %DB::sub value for dunk with specified args';
45 }
46
47 done_testing;