From Code to Community: Sponsoring The Perl and Raku Conference 2025 Learn more

use strict;
use Test::Stream::HashBase accessors => [qw/item/];
use Carp qw/croak confess/;
use Scalar::Util qw/reftype blessed/;
sub init {
my $self = shift;
croak "'item' is a required attribute"
unless $self->{+ITEM};
$self->SUPER::init();
}
sub name { '<SCALAR>' }
sub operator { '${...}' }
sub verify {
my $self = shift;
my %params = @_;
my ($got, $exists) = @params{qw/got exists/};
return 0 unless $exists;
return 0 unless defined $got;
return 0 unless ref($got);
return 0 unless reftype($got) eq 'SCALAR';
return 1;
}
sub deltas {
my $self = shift;
my %params = @_;
my ($got, $convert, $seen) = @params{qw/got convert seen/};
my $item = $self->{+ITEM};
my $check = $convert->($item);
return (
$check->run(
id => ['SCALAR' => '$*'],
got => $$got,
convert => $convert,
seen => $seen,
exists => 1,
),
);
}
1;
__END__
=pod
=encoding UTF-8
=head1 NAME
Test::Stream::Compare::Scalar - Representation of a Scalar Ref in deep
comparisons
=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
This is used in deep comparisons to represent a scalar reference.
=head1 SYNOPSIS
my $sr = Test::Stream::Compare::Scalar->new(item => 'foo');
is([\'foo'], $sr, "pass");
is([\'bar'], $sr, "fail, different value");
is(['foo'], $sr, "fail, not a ref");
=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