/*-------------------------------------------------------------------------
* drawElements Internal Test Module
* ---------------------------------
*
* Copyright 2014 The Android Open Source Project
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*
*//*!
* \file
* \brief Image IO tests.
*//*--------------------------------------------------------------------*/
#include "ditImageIOTests.hpp"
#include "tcuResource.hpp"
#include "tcuImageIO.hpp"
#include "tcuTexture.hpp"
#include "tcuTestLog.hpp"
#include "tcuFormatUtil.hpp"
#include "deUniquePtr.hpp"
#include "deString.h"
namespace dit
{
using tcu::TestLog;
// \todo [2013-05-28 pyry] Image output cases!
class ImageReadCase : public tcu::TestCase
{
public:
ImageReadCase (tcu::TestContext& testCtx, const char* name, const char* filename, deUint32 expectedHash)
: TestCase (testCtx, name, filename)
, m_filename (filename)
, m_expectedHash (expectedHash)
{
}
IterateResult iterate (void)
{
m_testCtx.getLog() << TestLog::Message << "Loading image from file '" << m_filename << "'" << TestLog::EndMessage;
tcu::TextureLevel texture;
tcu::ImageIO::loadImage(texture, m_testCtx.getArchive(), m_filename.c_str());
m_testCtx.getLog() << TestLog::Message << "Loaded " << texture.getWidth() << "x" << texture.getHeight() << "x" << texture.getDepth() << " image with format " << texture.getFormat() << TestLog::EndMessage;
// Check that layout is as expected
TCU_CHECK(texture.getAccess().getRowPitch() == texture.getWidth()*texture.getFormat().getPixelSize());
TCU_CHECK(texture.getAccess().getSlicePitch() == texture.getAccess().getRowPitch()*texture.getAccess().getHeight());
const int imageSize = texture.getAccess().getSlicePitch()*texture.getDepth();
const deUint32 hash = deMemoryHash(texture.getAccess().getDataPtr(), imageSize);
if (hash != m_expectedHash)
{
m_testCtx.getLog() << TestLog::Message << "ERROR: expected hash " << tcu::toHex(m_expectedHash) << ", got " << tcu::toHex(hash) << TestLog::EndMessage;
m_testCtx.getLog() << TestLog::Image("Image", "Loaded image", texture.getAccess());
m_testCtx.setTestResult(QP_TEST_RESULT_FAIL, "Hash check failed");
}
else
m_testCtx.setTestResult(QP_TEST_RESULT_PASS, "Pass");
return STOP;
}
private:
const std::string m_filename;
const deUint32 m_expectedHash;
};
class ImageReadTests : public tcu::TestCaseGroup
{
public:
ImageReadTests (tcu::TestContext& testCtx)
: TestCaseGroup(testCtx, "read", "Image read tests")
{
}
void init (void)
{
addChild(new ImageReadCase(m_testCtx, "rgb24_256x256", "data/imageio/rgb24_256x256.png", 0x6efad777));
addChild(new ImageReadCase(m_testCtx, "rgb24_209x181", "data/imageio/rgb24_209x181.png", 0xfd6ea668));
addChild(new ImageReadCase(m_testCtx, "rgba32_256x256", "data/imageio/rgba32_256x256.png", 0xcf4883da));
addChild(new ImageReadCase(m_testCtx, "rgba32_207x219", "data/imageio/rgba32_207x219.png", 0x404ba06b));
}
};
ImageIOTests::ImageIOTests(tcu::TestContext& testCtx)
: TestCaseGroup(testCtx, "image_io", "Image read and write tests")
{
}
ImageIOTests::~ImageIOTests (void)
{
}
void ImageIOTests::init (void)
{
addChild(new ImageReadTests(m_testCtx));
}
} // dit