Kaydet (Commit) 9825e169 authored tarafından David Tardon's avatar David Tardon

add test for swapping of GraphicObject

Change-Id: I341f52e5dfedb61130545cf30ff61e891abc7e04
üst 2a197185
# -*- Mode: makefile-gmake; tab-width: 4; indent-tabs-mode: t -*-
#
# This file is part of the LibreOffice project.
#
# This Source Code Form is subject to the terms of the Mozilla Public
# License, v. 2.0. If a copy of the MPL was not distributed with this
# file, You can obtain one at http://mozilla.org/MPL/2.0/.
#
$(eval $(call gb_CppunitTest_CppunitTest,svtools_graphic))
$(eval $(call gb_CppunitTest_use_externals,svtools_graphic,\
boost_headers \
))
$(eval $(call gb_CppunitTest_use_api,svtools_graphic, \
offapi \
udkapi \
))
$(eval $(call gb_CppunitTest_use_ure,svtools_graphic))
$(eval $(call gb_CppunitTest_use_vcl,svtools_graphic))
$(eval $(call gb_CppunitTest_use_libraries,svtools_graphic, \
comphelper \
cppu \
cppuhelper \
tl \
sal \
svt \
test \
unotest \
vcl \
$(gb_UWINAPI) \
))
$(eval $(call gb_CppunitTest_use_configuration,svtools_graphic))
$(eval $(call gb_CppunitTest_use_components,svtools_graphic,\
configmgr/source/configmgr \
ucb/source/core/ucb1 \
ucb/source/ucp/file/ucpfile1 \
))
$(eval $(call gb_CppunitTest_add_exception_objects,svtools_graphic, \
svtools/qa/unit/GraphicObjectTest \
))
# vim: set noet sw=4 ts=4:
...@@ -29,6 +29,7 @@ $(eval $(call gb_Module_add_l10n_targets,svtools,\ ...@@ -29,6 +29,7 @@ $(eval $(call gb_Module_add_l10n_targets,svtools,\
)) ))
$(eval $(call gb_Module_add_check_targets,svtools,\ $(eval $(call gb_Module_add_check_targets,svtools,\
CppunitTest_svtools_graphic \
CppunitTest_svtools_html \ CppunitTest_svtools_html \
)) ))
......
/* -*- Mode: C++; tab-width: 4; indent-tabs-mode: nil; c-basic-offset: 4 -*- */
/*
* This file is part of the LibreOffice project.
*
* This Source Code Form is subject to the terms of the Mozilla Public
* License, v. 2.0. If a copy of the MPL was not distributed with this
* file, You can obtain one at http://mozilla.org/MPL/2.0/.
*
*/
#include <cppunit/extensions/HelperMacros.h>
#include "cppunit/plugin/TestPlugIn.h"
#include <svtools/grfmgr.hxx>
#include <test/bootstrapfixture.hxx>
#include <tools/stream.hxx>
#include <vcl/image.hxx>
namespace
{
class GraphicObjectTest: public test::BootstrapFixture
{
public:
void testSwap();
private:
DECL_LINK(getLinkStream, GraphicObject*);
private:
CPPUNIT_TEST_SUITE(GraphicObjectTest);
CPPUNIT_TEST(testSwap);
CPPUNIT_TEST_SUITE_END();
};
static const char aGraphicFile[] = "/svtools/qa/unit/data/graphic.png";
static const sal_uLong nGraphicSizeBytes = 4800;
const Graphic lcl_loadGraphic(const rtl::OUString &rUrl)
{
const Image aImage(rUrl);
return Graphic(aImage.GetBitmapEx());
}
IMPL_LINK(GraphicObjectTest, getLinkStream, GraphicObject*, /*pGraphObj*/)
{
return reinterpret_cast<sal_IntPtr>(GRFMGR_AUTOSWAPSTREAM_LINK);
}
void GraphicObjectTest::testSwap()
{
// simple non-linked case
{
GraphicObject aGraphObj(lcl_loadGraphic(getURLFromSrc(aGraphicFile)));
CPPUNIT_ASSERT(!aGraphObj.HasSwapStreamHdl());
CPPUNIT_ASSERT(!aGraphObj.IsSwappedOut());
CPPUNIT_ASSERT_EQUAL(nGraphicSizeBytes, aGraphObj.GetGraphic().GetSizeBytes());
// swap out
CPPUNIT_ASSERT(aGraphObj.SwapOut());
CPPUNIT_ASSERT(aGraphObj.IsSwappedOut());
// swap in
CPPUNIT_ASSERT(aGraphObj.SwapIn());
CPPUNIT_ASSERT(!aGraphObj.IsSwappedOut());
// the data are still there
CPPUNIT_ASSERT_EQUAL(nGraphicSizeBytes, aGraphObj.GetGraphic().GetSizeBytes());
}
// linked case
{
GraphicObject aGraphObj(lcl_loadGraphic(getURLFromSrc(aGraphicFile)));
aGraphObj.SetSwapStreamHdl(LINK(this, GraphicObjectTest, getLinkStream));
CPPUNIT_ASSERT(aGraphObj.HasSwapStreamHdl());
CPPUNIT_ASSERT(!aGraphObj.IsSwappedOut());
CPPUNIT_ASSERT_EQUAL(nGraphicSizeBytes, aGraphObj.GetGraphic().GetSizeBytes());
// swap out
CPPUNIT_ASSERT(aGraphObj.SwapOut());
CPPUNIT_ASSERT(aGraphObj.IsSwappedOut());
// swap in
CPPUNIT_ASSERT(aGraphObj.SwapIn());
CPPUNIT_ASSERT(!aGraphObj.IsSwappedOut());
// the data are still there
CPPUNIT_ASSERT_EQUAL(nGraphicSizeBytes, aGraphObj.GetGraphic().GetSizeBytes());
}
// combination of two GraphicObjects
{
GraphicObject aGraphObj(lcl_loadGraphic(getURLFromSrc(aGraphicFile)));
GraphicObject aGraphObj2(aGraphObj);
aGraphObj2.SetSwapStreamHdl(LINK(this, GraphicObjectTest, getLinkStream));
CPPUNIT_ASSERT(!aGraphObj.IsSwappedOut());
CPPUNIT_ASSERT(!aGraphObj2.IsSwappedOut());
CPPUNIT_ASSERT_EQUAL(nGraphicSizeBytes, aGraphObj.GetGraphic().GetSizeBytes());
CPPUNIT_ASSERT_EQUAL(nGraphicSizeBytes, aGraphObj2.GetGraphic().GetSizeBytes());
// GraphicObjects never share the same Graphic. A new one is created as one step during
// registration of the GraphicObject at GraphicManager.
// swap out
CPPUNIT_ASSERT(aGraphObj.SwapOut());
CPPUNIT_ASSERT(aGraphObj.IsSwappedOut());
CPPUNIT_ASSERT(!aGraphObj2.IsSwappedOut());
CPPUNIT_ASSERT(aGraphObj2.SwapOut());
CPPUNIT_ASSERT(aGraphObj2.IsSwappedOut());
// swap in
CPPUNIT_ASSERT(aGraphObj2.SwapIn());
CPPUNIT_ASSERT(!aGraphObj2.IsSwappedOut());
CPPUNIT_ASSERT(aGraphObj.IsSwappedOut());
CPPUNIT_ASSERT(aGraphObj.SwapIn());
CPPUNIT_ASSERT(!aGraphObj.IsSwappedOut());
// the data are still there
CPPUNIT_ASSERT_EQUAL(nGraphicSizeBytes, aGraphObj.GetGraphic().GetSizeBytes());
CPPUNIT_ASSERT_EQUAL(nGraphicSizeBytes, aGraphObj2.GetGraphic().GetSizeBytes());
}
}
CPPUNIT_TEST_SUITE_REGISTRATION(GraphicObjectTest);
CPPUNIT_PLUGIN_IMPLEMENT();
}
/* vim:set shiftwidth=4 softtabstop=4 expandtab: */
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment