/* Copyright 2013 Christian Henning Use, modification and distribution are subject to the Boost Software License, Version 1.0. (See accompanying file LICENSE_1_0.txt or copy at http://www.boost.org/LICENSE_1_0.txt). */ #define BOOST_TEST_MODULE pnm_test #include #include #include #include #include #include "mandel_view.hpp" #include "paths.hpp" #include "subimage_test.hpp" using namespace std; using namespace boost; using namespace gil; typedef pnm_tag tag_t; BOOST_AUTO_TEST_SUITE( gil_io_pnm_tests ) #ifdef BOOST_GIL_IO_TEST_ALLOW_READING_IMAGES BOOST_AUTO_TEST_CASE( read_image_info_using_string ) { { typedef get_reader_backend< const std::string , tag_t >::type backend_t; backend_t backend = read_image_info( pnm_filename , tag_t() ); BOOST_CHECK_EQUAL( backend._info._width , 256u ); BOOST_CHECK_EQUAL( backend._info._height, 256u ); } { ifstream in( pnm_filename.c_str(), ios::binary ); typedef get_reader_backend< ifstream , tag_t >::type backend_t; backend_t backend = read_image_info( in , tag_t() ); BOOST_CHECK_EQUAL( backend._info._width , 256u ); BOOST_CHECK_EQUAL( backend._info._height, 256u ); } { FILE* file = fopen( pnm_filename.c_str(), "rb" ); typedef get_reader_backend< FILE* , tag_t >::type backend_t; backend_t backend = read_image_info( file , tag_t() ); BOOST_CHECK_EQUAL( backend._info._width , 256u ); BOOST_CHECK_EQUAL( backend._info._height, 256u ); } } BOOST_AUTO_TEST_CASE( read_image_test ) { { rgb8_image_t img; read_image( pnm_filename, img, tag_t() ); BOOST_CHECK_EQUAL( img.width() , 256u ); BOOST_CHECK_EQUAL( img.height(), 256u ); } { ifstream in( pnm_filename.c_str(), ios::binary ); rgb8_image_t img; read_image( in, img, tag_t() ); BOOST_CHECK_EQUAL( img.width() , 256u ); BOOST_CHECK_EQUAL( img.height(), 256u ); } { FILE* file = fopen( pnm_filename.c_str(), "rb" ); rgb8_image_t img; read_image( file, img, tag_t() ); BOOST_CHECK_EQUAL( img.width() , 256u ); BOOST_CHECK_EQUAL( img.height(), 256u ); } } BOOST_AUTO_TEST_CASE( read_and_convert_image_test ) { { rgb8_image_t img; read_and_convert_image( pnm_filename, img, tag_t() ); BOOST_CHECK_EQUAL( img.width() , 256u ); BOOST_CHECK_EQUAL( img.height(), 256u ); } { ifstream in( pnm_filename.c_str(), ios::binary ); rgb8_image_t img; read_and_convert_image( in, img, tag_t() ); BOOST_CHECK_EQUAL( img.width() , 256u ); BOOST_CHECK_EQUAL( img.height(), 256u ); } { FILE* file = fopen( pnm_filename.c_str(), "rb" ); rgb8_image_t img; read_and_convert_image( file, img, tag_t() ); BOOST_CHECK_EQUAL( img.width() , 256u ); BOOST_CHECK_EQUAL( img.height(), 256u ); } } BOOST_AUTO_TEST_CASE( read_view_test ) { { rgb8_image_t img( 256, 256 ); read_view( pnm_filename, view( img ), tag_t() ); } { ifstream in( pnm_filename.c_str(), ios::binary ); rgb8_image_t img( 256, 256 ); read_view( in, view( img ), tag_t() ); } { FILE* file = fopen( pnm_filename.c_str(), "rb" ); rgb8_image_t img( 256, 256 ); read_view( file, view( img ), tag_t() ); } } BOOST_AUTO_TEST_CASE( read_and_convert_view_test ) { { rgb8_image_t img( 256, 256 ); read_and_convert_view( pnm_filename, view( img ), tag_t() ); } { ifstream in( pnm_filename.c_str(), ios::binary ); rgb8_image_t img( 256, 256 ); read_and_convert_view( in, view( img ), tag_t() ); } { FILE* file = fopen( pnm_filename.c_str(), "rb" ); rgb8_image_t img( 256, 256 ); read_and_convert_view( file , view( img ) , tag_t() ); } } #endif // BOOST_GIL_IO_TEST_ALLOW_READING_IMAGES #ifdef BOOST_GIL_IO_TEST_ALLOW_WRITING_IMAGES BOOST_AUTO_TEST_CASE( write_view_test ) { { string filename( pnm_out + "write_test_string.pnm" ); write_view( filename , create_mandel_view( 320, 240 , rgb8_pixel_t( 0, 0, 255 ) , rgb8_pixel_t( 0, 255, 0 ) ) , tag_t() ); } { string filename( pnm_out + "write_test_ofstream.pnm" ); ofstream out( filename.c_str(), ios::out | ios::binary ); write_view( out , create_mandel_view( 320, 240 , rgb8_pixel_t( 0, 0, 255 ) , rgb8_pixel_t( 0, 255, 0 ) ) , tag_t() ); } { string filename( pnm_out + "write_test_file.pnm" ); FILE* file = fopen( filename.c_str(), "wb" ); write_view( file , create_mandel_view( 320, 240 , rgb8_pixel_t( 0, 0, 255 ) , rgb8_pixel_t( 0, 255, 0 ) ) , tag_t() ); } { string filename( pnm_out + "write_test_info.pnm" ); FILE* file = fopen( filename.c_str(), "wb" ); image_write_info< tag_t > info; write_view( file , create_mandel_view( 320, 240 , rgb8_pixel_t( 0, 0, 255 ) , rgb8_pixel_t( 0, 255, 0 ) ) , info ); } } #endif // BOOST_GIL_IO_TEST_ALLOW_WRITING_IMAGES #ifdef BOOST_GIL_IO_TEST_ALLOW_READING_IMAGES BOOST_AUTO_TEST_CASE( stream_test ) { // 1. Read an image. ifstream in( pnm_filename.c_str(), ios::binary ); rgb8_image_t img; read_image( in, img, tag_t() ); // 2. Write image to in-memory buffer. stringstream out_buffer( ios_base::in | ios_base::out | ios_base::binary ); write_view( out_buffer, view( img ), tag_t() ); // 3. Copy in-memory buffer to another. stringstream in_buffer( ios_base::in | ios_base::out | ios_base::binary ); in_buffer << out_buffer.rdbuf(); // 4. Read in-memory buffer to gil image rgb8_image_t dst; read_image( in_buffer, dst, tag_t() ); // 5. Write out image. string filename( pnm_out + "stream_test.pnm" ); ofstream out( filename.c_str(), ios_base::binary ); #ifdef BOOST_GIL_IO_TEST_ALLOW_WRITING_IMAGES write_view( out, view( dst ), tag_t() ); #endif // BOOST_GIL_IO_TEST_ALLOW_WRITING_IMAGES } BOOST_AUTO_TEST_CASE( stream_test_2 ) { filebuf in_buf; if( !in_buf.open( pnm_filename.c_str(), ios::in | ios::binary ) ) { BOOST_CHECK( false ); } istream in( &in_buf ); rgb8_image_t img; read_image( in, img, tag_t() ); } BOOST_AUTO_TEST_CASE( subimage_test ) { run_subimage_test< rgb8_image_t, tag_t >( pnm_filename , point_t( 0, 0 ) , point_t( 50, 50 ) ); run_subimage_test< rgb8_image_t, tag_t >( pnm_filename , point_t( 103, 103 ) , point_t( 50, 50 ) ); } BOOST_AUTO_TEST_CASE( dynamic_image_test ) { typedef mpl::vector< gray8_image_t , gray16_image_t , rgb8_image_t , gray1_image_t > my_img_types; any_image< my_img_types > runtime_image; read_image( pnm_filename.c_str() , runtime_image , tag_t() ); #ifdef BOOST_GIL_IO_TEST_ALLOW_WRITING_IMAGES write_view( pnm_out + "dynamic_image_test.pnm" , view( runtime_image ) , tag_t() ); #endif // BOOST_GIL_IO_TEST_ALLOW_WRITING_IMAGES } #endif // BOOST_GIL_IO_TEST_ALLOW_READING_IMAGES BOOST_AUTO_TEST_SUITE_END()