—package
Test::Stream::Compare::Ref;
use
strict;
use
warnings;
sub
init {
my
$self
=
shift
;
croak
"'input' is a required attribute"
unless
$self
->{+INPUT};
croak
"'input' must be a reference, got '"
.
$self
->{+INPUT} .
"'"
unless
ref
$self
->{+INPUT};
$self
->SUPER::init();
}
sub
operator {
'=='
}
sub
name { render_ref(
$_
[0]->{+INPUT}) };
sub
verify {
my
$self
=
shift
;
my
%params
=
@_
;
my
(
$got
,
$exists
) =
@params
{
qw/got exists/
};
return
0
unless
$exists
;
my
$in
=
$self
->{+INPUT};
return
0
unless
ref
$in
;
return
0
unless
ref
$got
;
my
$in_type
= rtype(
$in
);
my
$got_type
= rtype(
$got
);
return
0
unless
$in_type
eq
$got_type
;
# Don't let overloading mess with us.
return
refaddr(
$in
) == refaddr(
$got
);
}
1;
__END__
=pod
=encoding UTF-8
=head1 NAME
Test::Stream::Compare::Ref - Ref comparison
=head1 DEPRECATED
B<This distribution is deprecated> in favor of L<Test2>, L<Test2::Suite>, and
L<Test2::Workflow>.
See L<Test::Stream::Manual::ToTest2> for a conversion guide.
=head1 DESCRIPTION
Used to compare 2 refs in a deep comparison.
=head1 SYNOPSIS
my $ref = {};
my $check = Test::Stream::Compare::Ref->new(input => $ref);
# Passes
is( [$ref], [$check], "The array contains the exact ref we want" );
# Fails, they both may be empty hashes, but we are looking for a specific
# reference.
is( [{}], [$check], "This will fail");
=head1 SOURCE
The source code repository for Test::Stream can be found at
=head1 MAINTAINERS
=over 4
=item Chad Granum E<lt>exodist@cpan.orgE<gt>
=back
=head1 AUTHORS
=over 4
=item Chad Granum E<lt>exodist@cpan.orgE<gt>
=back
=head1 COPYRIGHT
Copyright 2015 Chad Granum E<lt>exodist7@gmail.comE<gt>.
This program is free software; you can redistribute it and/or
modify it under the same terms as Perl itself.
=cut