261 lines
7.8 KiB
C++
261 lines
7.8 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/screenshot_test.hxx"
|
|
|
|
#include <com/sun/star/util/XCloseable.hpp>
|
|
#include <com/sun/star/frame/Desktop.hpp>
|
|
#include <comphelper/processfactory.hxx>
|
|
#include <vcl/abstdlg.hxx>
|
|
#include <vcl/pngwrite.hxx>
|
|
#include <vcl/svapp.hxx>
|
|
#include <unotools/configmgr.hxx>
|
|
#include <unotools/syslocaleoptions.hxx>
|
|
|
|
|
|
namespace {
|
|
void splitHelpId( const OString& rHelpId, OUString& rDirname, OUString &rBasename )
|
|
{
|
|
sal_Int32 nIndex = rHelpId.lastIndexOf( '/' );
|
|
|
|
if( nIndex > 0 )
|
|
rDirname = OStringToOUString( rHelpId.copy( 0, nIndex ), RTL_TEXTENCODING_UTF8 );
|
|
|
|
if( rHelpId.getLength() > nIndex+1 )
|
|
rBasename= OStringToOUString( rHelpId.copy( nIndex+1 ), RTL_TEXTENCODING_UTF8 );
|
|
}
|
|
}
|
|
|
|
using namespace css;
|
|
using namespace css::uno;
|
|
|
|
ScreenshotTest::ScreenshotTest()
|
|
: m_aScreenshotDirectory("screenshots"),
|
|
maKnownDialogs()
|
|
{
|
|
SvtSysLocaleOptions localeOptions;
|
|
maCurrentLanguage = localeOptions.GetRealUILanguageTag().getBcp47();
|
|
}
|
|
|
|
ScreenshotTest::~ScreenshotTest()
|
|
{
|
|
}
|
|
|
|
void ScreenshotTest::setUp()
|
|
{
|
|
test::BootstrapFixture::setUp();
|
|
|
|
mxDesktop = css::frame::Desktop::create( comphelper::getComponentContext(getMultiServiceFactory()) );
|
|
CPPUNIT_ASSERT_MESSAGE("no desktop!", mxDesktop.is());
|
|
|
|
osl::Directory::create( m_directories.getURLFromWorkdir( OUStringToOString(m_aScreenshotDirectory, RTL_TEXTENCODING_UTF8).getStr())) ;
|
|
|
|
// initialize maKnownDialogs
|
|
if (maKnownDialogs.empty())
|
|
{
|
|
registerKnownDialogsByID(maKnownDialogs);
|
|
}
|
|
}
|
|
|
|
void ScreenshotTest::implSaveScreenshot(const Bitmap& rScreenshot, const OString& rScreenshotId)
|
|
{
|
|
OUString aDirname, aBasename;
|
|
splitHelpId(rScreenshotId, aDirname, aBasename);
|
|
aDirname = m_aScreenshotDirectory + "/" + aDirname +
|
|
( (maCurrentLanguage == "en-US") ? OUString() : "/" + maCurrentLanguage );
|
|
|
|
auto const path = m_directories.getURLFromWorkdir(
|
|
OUStringToOString(aDirname, RTL_TEXTENCODING_UTF8).getStr());
|
|
auto const e = osl::Directory::createPath(path);
|
|
if (e != osl::FileBase::E_EXIST) {
|
|
CPPUNIT_ASSERT_EQUAL_MESSAGE(
|
|
OUStringToOString(
|
|
"Failed to create " + path, RTL_TEXTENCODING_UTF8).getStr(),
|
|
osl::FileBase::E_None, e);
|
|
}
|
|
|
|
OUString aFullPath = m_directories.getPathFromWorkdir(OUStringToOString("/" + aDirname + "/" + aBasename + ".png",RTL_TEXTENCODING_UTF8).getStr());
|
|
SvFileStream aNew(aFullPath, StreamMode::WRITE | StreamMode::TRUNC);
|
|
CPPUNIT_ASSERT_MESSAGE(OUStringToOString("Failed to open <" + aFullPath + ">: " + OUString::number(sal_uInt32(aNew.GetErrorCode())), RTL_TEXTENCODING_UTF8).getStr(), aNew.IsOpen());
|
|
|
|
vcl::PNGWriter aPNGWriter(rScreenshot);
|
|
aPNGWriter.Write(aNew);
|
|
}
|
|
|
|
void ScreenshotTest::saveScreenshot(VclAbstractDialog const & rDialog)
|
|
{
|
|
const Bitmap aScreenshot(rDialog.createScreenshot());
|
|
|
|
if (!aScreenshot.IsEmpty())
|
|
{
|
|
const OString aScreenshotId = rDialog.GetScreenshotId();
|
|
|
|
if (!aScreenshotId.isEmpty())
|
|
{
|
|
implSaveScreenshot(aScreenshot, aScreenshotId);
|
|
}
|
|
}
|
|
}
|
|
|
|
void ScreenshotTest::saveScreenshot(Dialog& rDialog)
|
|
{
|
|
const Bitmap aScreenshot(rDialog.createScreenshot());
|
|
|
|
if (!aScreenshot.IsEmpty())
|
|
{
|
|
const OString aScreenshotId = rDialog.GetScreenshotId();
|
|
|
|
if (!aScreenshotId.isEmpty())
|
|
{
|
|
implSaveScreenshot(aScreenshot, aScreenshotId);
|
|
}
|
|
}
|
|
}
|
|
|
|
VclPtr<VclAbstractDialog> ScreenshotTest::createDialogByName(const OString& rName)
|
|
{
|
|
const mapType::const_iterator aHit = maKnownDialogs.find(rName);
|
|
|
|
if (aHit != maKnownDialogs.end())
|
|
{
|
|
return createDialogByID((*aHit).second);
|
|
}
|
|
|
|
return VclPtr<VclAbstractDialog>();
|
|
}
|
|
|
|
void ScreenshotTest::dumpDialogToPath(VclAbstractDialog& rDialog)
|
|
{
|
|
const std::vector<OString> aPageDescriptions(rDialog.getAllPageUIXMLDescriptions());
|
|
|
|
if (aPageDescriptions.size())
|
|
{
|
|
for (size_t a(0); a < aPageDescriptions.size(); a++)
|
|
{
|
|
if (rDialog.selectPageByUIXMLDescription(aPageDescriptions[a]))
|
|
{
|
|
saveScreenshot(rDialog);
|
|
}
|
|
else
|
|
{
|
|
CPPUNIT_ASSERT(false);
|
|
}
|
|
}
|
|
}
|
|
else
|
|
{
|
|
saveScreenshot(rDialog);
|
|
}
|
|
}
|
|
|
|
void ScreenshotTest::dumpDialogToPath(Dialog& rDialog)
|
|
{
|
|
const std::vector<OString> aPageDescriptions(rDialog.getAllPageUIXMLDescriptions());
|
|
|
|
if (aPageDescriptions.size())
|
|
{
|
|
for (size_t a(0); a < aPageDescriptions.size(); a++)
|
|
{
|
|
if (rDialog.selectPageByUIXMLDescription(aPageDescriptions[a]))
|
|
{
|
|
saveScreenshot(rDialog);
|
|
}
|
|
else
|
|
{
|
|
CPPUNIT_ASSERT(false);
|
|
}
|
|
}
|
|
}
|
|
else
|
|
{
|
|
saveScreenshot(rDialog);
|
|
}
|
|
}
|
|
|
|
void ScreenshotTest::dumpDialogToPath(const OString& rUIXMLDescription)
|
|
{
|
|
if (!rUIXMLDescription.isEmpty())
|
|
{
|
|
VclPtrInstance<Dialog> pDialog(Application::GetDefDialogParent(), WB_STDDIALOG | WB_SIZEABLE, Dialog::InitFlag::NoParent);
|
|
|
|
{
|
|
VclBuilder aBuilder(pDialog, VclBuilderContainer::getUIRootDir(), OStringToOUString(rUIXMLDescription, RTL_TEXTENCODING_UTF8));
|
|
vcl::Window *pRoot = aBuilder.get_widget_root();
|
|
Dialog *pRealDialog = dynamic_cast<Dialog*>(pRoot);
|
|
|
|
if (!pRealDialog)
|
|
{
|
|
pRealDialog = pDialog;
|
|
}
|
|
|
|
pRealDialog->SetText(utl::ConfigManager::getProductName());
|
|
pRealDialog->SetStyle(pDialog->GetStyle() | WB_CLOSEABLE);
|
|
|
|
dumpDialogToPath(*pRealDialog);
|
|
}
|
|
|
|
pDialog.disposeAndClear();
|
|
}
|
|
}
|
|
|
|
void ScreenshotTest::processAllKnownDialogs()
|
|
{
|
|
for (mapType::const_iterator i = getKnownDialogs().begin(); i != getKnownDialogs().end(); ++i)
|
|
{
|
|
ScopedVclPtr<VclAbstractDialog> pDlg(createDialogByID((*i).second));
|
|
|
|
if (pDlg)
|
|
{
|
|
// known dialog, dump screenshot to path
|
|
dumpDialogToPath(*pDlg);
|
|
}
|
|
else
|
|
{
|
|
// unknown dialog, should not happen in this basic loop.
|
|
// You have probably forgotten to add a case and
|
|
// implementastion to createDialogByID, please do this
|
|
}
|
|
}
|
|
}
|
|
|
|
void ScreenshotTest::processDialogBatchFile(const OUString& rFile)
|
|
{
|
|
test::Directories aDirectories;
|
|
const OUString aURL(aDirectories.getURLFromSrc(rFile));
|
|
SvFileStream aStream(aURL, StreamMode::READ);
|
|
OString aNextUIFile;
|
|
const OString aComment("#");
|
|
|
|
while (aStream.ReadLine(aNextUIFile))
|
|
{
|
|
if (!aNextUIFile.isEmpty() && !aNextUIFile.startsWith(aComment))
|
|
{
|
|
// first check if it's a known dialog
|
|
ScopedVclPtr<VclAbstractDialog> pDlg(createDialogByName(aNextUIFile));
|
|
|
|
if (pDlg)
|
|
{
|
|
// known dialog, dump screenshot to path
|
|
dumpDialogToPath(*pDlg);
|
|
}
|
|
else
|
|
{
|
|
// unknown dialog, try fallback to generic created
|
|
// VclBuilder-generated instance. Keep in mind that Dialogs
|
|
// using this mechanism will probably not be layouted well
|
|
// since the setup/initialization part is missing. Thus,
|
|
// only use for fallback when only the UI file is available.
|
|
dumpDialogToPath(aNextUIFile);
|
|
}
|
|
}
|
|
}
|
|
}
|
|
|
|
/* vim:set shiftwidth=4 softtabstop=4 expandtab: */
|