Files
libreoffice/vcl/qa/cppunit/errorhandler.cxx
Gabor Kelemen 54d63ea296 tdf#42949 Fix IWYU warnings in vcl/qa/* & vcl/backendtest/*
Found with bin/find-unneeded-includes
Only removal proposals are dealt with here.

Change-Id: I2d5ab9fd1117a4c57eb42ca849daf0949a79ff50
Reviewed-on: https://gerrit.libreoffice.org/73999
Tested-by: Jenkins
Reviewed-by: Miklos Vajna <vmiklos@collabora.com>
2019-06-19 08:37:38 +02:00

69 lines
2.2 KiB
C++

/* -*- 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 <test/bootstrapfixture.hxx>
#include <cppunit/TestAssert.h>
#include <vcl/errinf.hxx>
class MockErrorHandler : private ErrorHandler
{
friend class ErrorHandlerTest;
protected:
virtual bool CreateString(const ErrorInfo *pErrInfo, OUString &rErrString) const override
{
if (pErrInfo->GetErrorCode().IsDynamic())
rErrString = "Dynamic error";
else
rErrString = "Non-dynamic error";
return true;
}
};
class ErrorHandlerTest : public test::BootstrapFixture
{
public:
ErrorHandlerTest() : BootstrapFixture(true, false) {}
void testGetErrorString();
CPPUNIT_TEST_SUITE(ErrorHandlerTest);
CPPUNIT_TEST(testGetErrorString);
CPPUNIT_TEST_SUITE_END();
};
void ErrorHandlerTest::testGetErrorString()
{
MockErrorHandler aErrHdlr;
std::unique_ptr<ErrorInfo> xErrorInfo;
OUString aErrStr;
CPPUNIT_ASSERT_MESSAGE("GetErrorString(ERRCODE_ABORT, aErrStr) should return false",
!ErrorHandler::GetErrorString(ERRCODE_ABORT, aErrStr));
// normally protected, but MockErrorHandler is a friend of this class
xErrorInfo = ErrorInfo::GetErrorInfo(ERRCODE_ABORT);
aErrHdlr.CreateString(xErrorInfo.get(), aErrStr);
CPPUNIT_ASSERT_EQUAL_MESSAGE("error message should be non-dynamic", OUString("Non-dynamic error"), aErrStr);
CPPUNIT_ASSERT_MESSAGE("GetErrorString(ERRCODE_NONE, aErrStr) should return false",
!ErrorHandler::GetErrorString(ERRCODE_NONE, aErrStr));
xErrorInfo = ErrorInfo::GetErrorInfo(ERRCODE_NONE);
aErrHdlr.CreateString(xErrorInfo.get(), aErrStr);
CPPUNIT_ASSERT_EQUAL_MESSAGE("error message should be non-dynamic", OUString("Non-dynamic error"), aErrStr);
}
CPPUNIT_TEST_SUITE_REGISTRATION(ErrorHandlerTest);
CPPUNIT_PLUGIN_IMPLEMENT();
/* vim:set shiftwidth=4 softtabstop=4 expandtab: */