color-profile-test.h revision c0092c87b724182672defa4f5f75a82c27f017dc
#ifndef SEEN_COLOR_PROFILE_TEST_H
#define SEEN_COLOR_PROFILE_TEST_H
#include <cxxtest/TestSuite.h>
#include <cassert>
#include "test-helpers.h"
#include "color-profile.h"
#include "color-profile-fns.h"
class ColorProfileTest : public CxxTest::TestSuite
{
public:
SPDocument* _doc;
ColorProfileTest() :
_doc(0)
{
}
virtual ~ColorProfileTest()
{
if ( _doc )
{
sp_document_unref( _doc );
}
}
static void createSuiteSubclass( ColorProfileTest*& dst )
{
Inkscape::ColorProfile *prof = static_cast<Inkscape::ColorProfile *>(g_object_new(COLORPROFILE_TYPE, NULL));
if ( prof ) {
if ( prof->rendering_intent == (guint)Inkscape::RENDERING_INTENT_UNKNOWN ) {
TS_ASSERT_EQUALS( prof->rendering_intent, (guint)Inkscape::RENDERING_INTENT_UNKNOWN );
dst = new ColorProfileTest();
}
g_object_unref(prof);
}
}
// createSuite and destroySuite get us per-suite setup and teardown
// without us having to worry about static initialization order, etc.
static ColorProfileTest *createSuite()
{
ColorProfileTest* suite = Inkscape::createSuiteAndDocument<ColorProfileTest>( createSuiteSubclass );
return suite;
}
static void destroySuite( ColorProfileTest *suite )
{
delete suite;
}
// ---------------------------------------------------------------
// ---------------------------------------------------------------
// ---------------------------------------------------------------
void testSetRenderingIntent()
{
struct {
gchar const *attr;
guint intVal;
}
const cases[] = {
{"auto", (guint)Inkscape::RENDERING_INTENT_AUTO},
{"perceptual", (guint)Inkscape::RENDERING_INTENT_PERCEPTUAL},
{"relative-colorimetric", (guint)Inkscape::RENDERING_INTENT_RELATIVE_COLORIMETRIC},
{"saturation", (guint)Inkscape::RENDERING_INTENT_SATURATION},
{"absolute-colorimetric", (guint)Inkscape::RENDERING_INTENT_ABSOLUTE_COLORIMETRIC},
{"something-else", (guint)Inkscape::RENDERING_INTENT_UNKNOWN},
{"auto2", (guint)Inkscape::RENDERING_INTENT_UNKNOWN},
};
Inkscape::ColorProfile *prof = static_cast<Inkscape::ColorProfile *>(g_object_new(COLORPROFILE_TYPE, NULL));
TS_ASSERT( prof );
SP_OBJECT(prof)->document = _doc;
for ( size_t i = 0; i < G_N_ELEMENTS( cases ); i++ ) {
std::string descr(cases[i].attr);
sp_object_set(SP_OBJECT(prof), SP_ATTR_RENDERING_INTENT, cases[i].attr);
TSM_ASSERT_EQUALS( descr, prof->rendering_intent, (guint)cases[i].intVal );
}
g_object_unref(prof);
}
void testSetLocal()
{
gchar const* cases[] = {
"local",
"something",
};
Inkscape::ColorProfile *prof = static_cast<Inkscape::ColorProfile *>(g_object_new(COLORPROFILE_TYPE, NULL));
TS_ASSERT( prof );
SP_OBJECT(prof)->document = _doc;
for ( size_t i = 0; i < G_N_ELEMENTS( cases ); i++ ) {
sp_object_set(SP_OBJECT(prof), SP_ATTR_LOCAL, cases[i]);
TS_ASSERT( prof->local );
if ( prof->local ) {
TS_ASSERT_EQUALS( std::string(prof->local), std::string(cases[i]) );
}
}
sp_object_set(SP_OBJECT(prof), SP_ATTR_LOCAL, NULL);
TS_ASSERT_EQUALS( prof->local, (gchar*)0 );
g_object_unref(prof);
}
void testSetName()
{
gchar const* cases[] = {
"name",
"something",
};
Inkscape::ColorProfile *prof = static_cast<Inkscape::ColorProfile *>(g_object_new(COLORPROFILE_TYPE, NULL));
TS_ASSERT( prof );
SP_OBJECT(prof)->document = _doc;
for ( size_t i = 0; i < G_N_ELEMENTS( cases ); i++ ) {
sp_object_set(SP_OBJECT(prof), SP_ATTR_NAME, cases[i]);
TS_ASSERT( prof->name );
if ( prof->name ) {
TS_ASSERT_EQUALS( std::string(prof->name), std::string(cases[i]) );
}
}
sp_object_set(SP_OBJECT(prof), SP_ATTR_NAME, NULL);
TS_ASSERT_EQUALS( prof->name, (gchar*)0 );
g_object_unref(prof);
}
};
#endif // SEEN_COLOR_PROFILE_TEST_H
/*
Local Variables:
mode:c++
c-file-style:"stroustrup"
c-file-offsets:((innamespace . 0)(inline-open . 0)(case-label . +))
indent-tabs-mode:nil
fill-column:99
End:
*/
// vim: filetype=cpp:expandtab:shiftwidth=4:tabstop=8:softtabstop=4:encoding=utf-8:textwidth=99 :