The Perl and Raku Conference 2025: Greenville, South Carolina - June 27-29 Learn more

NAME

Test::BSON - Test BSON documents

VERSION

This document describes Test::BSON version 0.01.

SYNOPSIS

bson_ok $bson, 'BSON is valid';
bson_is $bson, $expected_bson, 'BSON matches what we expected';

DESCRIPTION

BSON is a binary-encoded extension of JSON. Test::BSON makes it easy to verify that you have built a valid BSON document and that it matches what you expected.

EXPORTED TESTS

bson_ok

Test passes if the BSON document is valid.

bson_ok $bson, 'BSON is valid';

is_valid_bson is provided as an alternative to bson_ok using the same naming convention as Test::JSON but is not exported by default.

bson_is

Test passes if the two BSON documents are valid and evaluate to the same data structure.

bson_is $bson, $expected_bson, 'BSON matches what we expected';

Test::Differences is used to provide easy diagnostics of why the BSON documents did not match. For example:

Failed test 'BSON matches what we expected'
in t/bson.t at line 10.
+----+----------------+----------------+
| Elt|Got |Expected |
+----+----------------+----------------+
| 0|{ |{ |
| 1| BSON => [ | BSON => [ |
* 2| 'AWSUM!!', | 'awesome', *
| 3| '5.05', | '5.05', |
* 4| 1984 | 1986 *
| 5| ] | ] |
| 6|} |} |
+----+----------------+----------------+

is_bson is provided as an alternative to bson_is using the same naming convention as Test::JSON but is not exported by default.

SEE ALSO

This module uses BSON and Test::Differences, and is based on Test::JSON. Learn more about BSON at http://bsonspec.org/.

AUTHOR

Nick Patch <patch@cpan.org>

ACKNOWLEDGEMENTS

This module was forked from Test::JSYNC, which was forked from Test::JSON authored by Curtis “Ovid” Poe.

COPYRIGHT & LICENSE

© 2011–2012 Nick Patch

© 2005–2007 Curtis “Ovid” Poe

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