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
|
#include "ismrmrd/xml.h"
#include "ismrmrd/version.h"
#include "embedded_xml.h"
#include <boost/test/unit_test.hpp>
#include <sstream>
using namespace ISMRMRD;
BOOST_AUTO_TEST_SUITE(HeaderTest)
BOOST_AUTO_TEST_CASE(test_basic_xml_header)
{
IsmrmrdHeader header;
deserialize(basic_xml.c_str(),header);
std::stringstream stream;
serialize(header,stream);
IsmrmrdHeader header2;
deserialize(stream.str().c_str(),header2);
BOOST_CHECK_EQUAL(header,header2);
}
BOOST_AUTO_TEST_CASE(test_extended_xml_header)
{
IsmrmrdHeader header;
deserialize(extended_xml.c_str(),header);
std::stringstream stream;
serialize(header,stream);
BOOST_CHECK(header.encoding.at(1).parallelImaging);
BOOST_CHECK(header.encoding.at(1).parallelImaging->multiband);
BOOST_CHECK_EQUAL(header.encoding.at(1).parallelImaging.get().multiband.get().deltaKz,1.0f);
BOOST_CHECK_EQUAL(header.encoding.at(1).parallelImaging.get().multiband.get().multiband_factor,2);
BOOST_CHECK(header.sequenceParameters.get().diffusion);
BOOST_CHECK_EQUAL(header.sequenceParameters.get().diffusion.get().size(),3 );
IsmrmrdHeader header2;
deserialize(stream.str().c_str(),header2);
BOOST_CHECK_EQUAL(header,header2);
}
BOOST_AUTO_TEST_CASE(test_xml_header_locale)
{
IsmrmrdHeader header;
deserialize(basic_xml.c_str(), header);
std::stringstream stream1;
std::locale original_locale = std::locale::global(std::locale("C"));
serialize(header, stream1);
std::stringstream stream2;
std::locale::global(std::locale("C"));
serialize(header, stream2);
std::locale::global(original_locale);
BOOST_CHECK_EQUAL(stream1.str(), stream2.str());
}
BOOST_AUTO_TEST_SUITE_END()
|