NAME
Test::HexDifferences - Test binary as hexadecimal string
VERSION
1.001
SYNOPSIS
use
Test::HexDifferences;
eq_or_dump_diff(
$got
,
$expected
,
);
eq_or_dump_diff(
$got
,
$expected
,
$test_name
,
);
eq_or_dump_diff(
$got
,
$expected
,
{
address
=>
$start_address
,
format
=>
"%a : %4C : %d\n"
,
}
$test_name
,
);
If $got
or $expected
is undef
or a reference, the hexadecimal formatter is off. Then eq_or_dump_diff
is a text compare.
dumped_eq_dump_or_diff(
$got_value
,
$expected_dump
,
);
dumped_eq_dump_or_diff(
$got_value
,
$expected_dump
,
$test_name
,
);
dumped_eq_dump_or_diff(
$got_value
,
$expected_dump
,
{
address
=>
$start_address
,
format
=>
"%a : %4C : %d\n"
,
}
$test_name
,
);
See Test::HexDifferences::HexDump for the format description.
EXAMPLE
Inside of this Distribution is a directory named example. Run this *.t files.
DESCRIPTION
The are some special cases for testing binary data.
The ascii format is not good for e.g. a length byte 0x41 displayed as A.
Multibyte values are better shown as 1 value.
Structured binary e.g. 2 byte length followed by bytes better are shown as it is.
Compare 2 binary or 1 binary and a dump.
SUBROUTINES/METHODS
subroutine eq_or_dump_diff
eq_or_dump_diff(
$got_value
,
$expected_value
,
{
# optional hash reference
address
=>
$display_start_address
,
# optional
format
=>
$format_string
,
# optional
}
$test_name
,
# optional
);
subroutine dumped_eq_dump_or_diff
dumped_eq_dump_or_diff(
$got_value
,
$expected_dump
,
{
# optional hash reference
address
=>
$display_start_address
,
# optional
format
=>
$format_string
,
# optional
}
$test_name
,
# optional
);
DIAGNOSTICS
nothing
CONFIGURATION AND ENVIRONMENT
nothing
DEPENDENCIES
INCOMPATIBILITIES
none
BUGS AND LIMITATIONS
none
SEE ALSO
AUTHOR
Steffen Winkler
LICENSE AND COPYRIGHT
Copyright (c) 2012 - 2015, Steffen Winkler <steffenw at cpan.org>
. All rights reserved.
This module is free software; you can redistribute it and/or modify it under the same terms as Perl itself.