File: 33cacheinvalidationishard.t

package info (click to toggle)
libkavorka-perl 0.039-3
  • links: PTS, VCS
  • area: main
  • in suites: buster
  • size: 696 kB
  • sloc: perl: 2,850; makefile: 6; sh: 6
file content (68 lines) | stat: -rw-r--r-- 1,293 bytes parent folder | download
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
=pod

=encoding utf-8

=head1 PURPOSE

Cache invalidation is hard.

The optimized multi sub implementation is a form of caching.

Test that optimizations are invalidated correctly.

=head1 AUTHOR

Toby Inkster E<lt>tobyink@cpan.orgE<gt>.

=head1 COPYRIGHT AND LICENCE

This software is copyright (c) 2013-2014, 2017 by Toby Inkster.

This is free software; you can redistribute it and/or modify it under
the same terms as the Perl 5 programming language system itself.

=cut

use strict;
use warnings;
use Test::More;
use Test::Fatal;

{
	package Example;
	use Kavorka qw( multi method );
	
	multi method foo (ArrayRef $x) { 'array' }
}

{
	package Example2;
	use Kavorka qw( multi method );
	
	our @ISA = 'Example';
	
	multi method foo (HashRef $x) { 'hash' }
}

is( Example2->foo({}), 'hash' );
is( Example2->foo([]), 'array' );

like(
	exception { Example2->foo(\1) },
	qr{^Arguments to Example2::foo did not match any known signature for multi sub},
);

# Now we add a new implementation to Example, and check that the
# optimized dispatcher in Example2 gets updated!
{
	package Example;
	use Kavorka qw( multi method );
	
	multi method foo (ScalarRef $x) { 'scalar' }
}

is( Example2->foo({}), 'hash' );
is( Example2->foo([]), 'array' );
is( Example2->foo(\1), 'scalar' );

done_testing;