2
0
mirror of https://github.com/boostorg/gil.git synced 2026-02-17 13:52:09 +00:00
Files
gil/io/test/raw_test.cpp
Mateusz Łoskot 32fec9f05b Refactor library includes to #include <boost/gil/...>
Group include directives, sort within group:
* In headers of GIL core and extensions:
  1. boost/gil/extension/*
  2. boost/gil/*
  3. boost/*
  4. C++ standard library headers
* In programs:
  1. boost/gil/*
  2. boost/*
  3. C++ standard library headers
  4. "xxx.hpp" for local headers
Add basic guidelines to CONTRIBUTING.md.
Add/Remove #include <boost/config.hpp> or std headers un/necessary.
Rename gil_concept.hpp to concepts.hpp.
Remove gil_all.hpp - we already have all-in-one boost/gil.hpp.
Tidy up and unify copyright and license header.
Tidy up formatting and excessive whitespaces in some comments.
Remove Doxygen block with file description, author, date, etc.
Remove dead or commented pragmas and directives.
Trim trailing whitespaces.
2018-09-28 16:26:34 +02:00

124 lines
3.0 KiB
C++

//
// Copyright 2013 Christian Henning
//
// Distributed under 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 raw_test
#define BOOST_FILESYSTEM_VERSION 3
#define BOOST_GIL_IO_ADD_FS_PATH_SUPPORT
#include <boost/gil.hpp>
#include <boost/gil/extension/io/raw.hpp>
#include <boost/filesystem/convenience.hpp>
#include <boost/test/unit_test.hpp>
#include <fstream>
#include "mandel_view.hpp"
#include "paths.hpp"
#include "subimage_test.hpp"
using namespace std;
using namespace boost;
using namespace gil;
namespace fs = boost::filesystem;
typedef raw_tag tag_t;
BOOST_AUTO_TEST_SUITE( gil_io_raw_tests )
#ifdef BOOST_GIL_IO_TEST_ALLOW_READING_IMAGES
BOOST_AUTO_TEST_CASE( read_image_info_using_string )
{
{
/// raw_tag reader's can only constructed with char*, std::string, and LibRaw object
typedef get_reader_backend<const char*, tag_t>::type backend_t;
backend_t b = make_reader_backend(raw_filename.c_str(),
image_read_settings<raw_tag>());
backend_t backend = read_image_info(raw_filename, tag_t());
BOOST_CHECK_EQUAL( backend._info._width , 2176 );
BOOST_CHECK_EQUAL( backend._info._height, 1448 );
}
{
fs::path my_path( raw_filename );
typedef get_reader_backend<fs::path, tag_t>::type backend_t;
backend_t backend = read_image_info(my_path, tag_t());
BOOST_CHECK_EQUAL( backend._info._width , 2176 );
BOOST_CHECK_EQUAL( backend._info._height, 1448 );
}
}
BOOST_AUTO_TEST_CASE( read_image_test )
{
{
rgb8_image_t img;
read_image( raw_filename, img, tag_t() );
BOOST_CHECK_EQUAL( img.width() , 2176 );
BOOST_CHECK_EQUAL( img.height(), 1448 );
}
{
fs::path my_path( raw_filename );
rgb8_image_t img;
read_image( my_path, img, tag_t() );
BOOST_CHECK_EQUAL( img.width() , 2176 );
BOOST_CHECK_EQUAL( img.height(), 1448 );
}
}
BOOST_AUTO_TEST_CASE( read_and_convert_image_test )
{
rgb8_image_t img;
read_and_convert_image( raw_filename, img, tag_t() );
BOOST_CHECK_EQUAL( img.width() , 2176 );
BOOST_CHECK_EQUAL( img.height(), 1448 );
}
BOOST_AUTO_TEST_CASE( read_view_test )
{
rgb8_image_t img( 2176, 1448 );
read_view( raw_filename, view( img ), tag_t() );
}
BOOST_AUTO_TEST_CASE( read_and_convert_view_test )
{
rgb8_image_t img( 2176, 1448 );
read_and_convert_view( raw_filename, view( img ), tag_t() );
}
// BOOST_AUTO_TEST_CASE( subimage_test )
// {
// run_subimage_test<rgb8_image_t, tag_t>(raw_filename, point_t(0, 0), point_t(127, 1));
// run_subimage_test<rgb8_image_t, tag_t>(raw_filename, point_t(39, 7), point_t(50, 50));
// }
BOOST_AUTO_TEST_CASE( dynamic_image_test )
{
typedef mpl::vector<gray8_image_t, gray16_image_t, rgb8_image_t, rgba8_image_t> my_img_types;
any_image< my_img_types > runtime_image;
read_image(raw_filename.c_str(), runtime_image, tag_t());
}
#endif // BOOST_GIL_IO_TEST_ALLOW_READING_IMAGES
BOOST_AUTO_TEST_SUITE_END()