c06376cc1d
Now all logging is done after checking if the level in question is enabled or not (thanks to the macros LOG_XXX), which saves unnecessary conversions and stringification when said level is disabled. Change-Id: Icde31e067f60269563896f04f8b0d65643720766 Reviewed-on: https://gerrit.libreoffice.org/47885 Reviewed-by: Michael Meeks <michael.meeks@collabora.com> Tested-by: Michael Meeks <michael.meeks@collabora.com>
72 lines
1.7 KiB
C++
72 lines
1.7 KiB
C++
/* -*- Mode: C++; tab-width: 4; indent-tabs-mode: nil; c-basic-offset: 4; fill-column: 100 -*- */
|
|
/*
|
|
* 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 <config.h>
|
|
|
|
#include <cassert>
|
|
|
|
#include <Poco/Util/Application.h>
|
|
|
|
#include <Log.hpp>
|
|
#include <Util.hpp>
|
|
#include <Unit.hpp>
|
|
|
|
using Poco::Timestamp;
|
|
|
|
class UnitTimeout : public UnitWSD
|
|
{
|
|
std::atomic<bool> _timedOut;
|
|
public:
|
|
UnitTimeout()
|
|
: _timedOut(false)
|
|
{
|
|
setTimeout(10);
|
|
}
|
|
virtual void timeout() override
|
|
{
|
|
_timedOut = true;
|
|
UnitBase::timeout();
|
|
}
|
|
virtual void returnValue(int & retValue) override
|
|
{
|
|
if (!_timedOut)
|
|
{
|
|
LOG_INF("Failed to timeout");
|
|
retValue = Poco::Util::Application::EXIT_SOFTWARE;
|
|
}
|
|
else
|
|
{
|
|
assert(_setRetValue);
|
|
assert(_retValue == Poco::Util::Application::EXIT_SOFTWARE);
|
|
// we wanted a timeout.
|
|
retValue = Poco::Util::Application::EXIT_OK;
|
|
}
|
|
}
|
|
|
|
// sanity check the non-unit-test paths
|
|
static void testDefaultKits()
|
|
{
|
|
bool madeWSD = init(UnitType::Wsd, std::string());
|
|
assert(madeWSD);
|
|
delete UnitBase::Global;
|
|
UnitBase::Global = nullptr;
|
|
bool madeKit = init(UnitType::Kit, std::string());
|
|
assert(madeKit);
|
|
delete UnitBase::Global;
|
|
UnitBase::Global = nullptr;
|
|
}
|
|
};
|
|
|
|
UnitBase *unit_create_wsd(void)
|
|
{
|
|
UnitTimeout::testDefaultKits();
|
|
return new UnitTimeout();
|
|
}
|
|
|
|
/* vim:set shiftwidth=4 softtabstop=4 expandtab: */
|